summaryrefslogtreecommitdiff
path: root/omega/examples/substitution
diff options
context:
space:
mode:
authordhuth <derickhuth@gmail.com>2014-11-21 13:35:20 -0700
committerdhuth <derickhuth@gmail.com>2014-11-21 13:35:20 -0700
commita1834b22c43c282442b0cb164767e6c877cf0e5b (patch)
treebedc5be7d1bdb8d32c1868caa496a8a1530d8d8a /omega/examples/substitution
parentded84bb4aec7461738e7b7033d782a518e2c606b (diff)
parenteb9236c5353785472ae132f27e1cfb9f1e4264a5 (diff)
downloadchill-a1834b22c43c282442b0cb164767e6c877cf0e5b.tar.gz
chill-a1834b22c43c282442b0cb164767e6c877cf0e5b.tar.bz2
chill-a1834b22c43c282442b0cb164767e6c877cf0e5b.zip
Merge branch 'master' into doe
Diffstat (limited to 'omega/examples/substitution')
-rw-r--r--omega/examples/substitution35
1 files changed, 35 insertions, 0 deletions
diff --git a/omega/examples/substitution b/omega/examples/substitution
new file mode 100644
index 0000000..9d841fe
--- /dev/null
+++ b/omega/examples/substitution
@@ -0,0 +1,35 @@
+#
+# Test various variable substitution scenarios
+#
+
+symbolic n;
+
+# unimodular transformation
+#
+is := { [i,j] : 0 <=i<= 4 && 0 <= j<= 6 };
+t := { [i,j] -> [i2,j2] : i2 = i+j && j2 = i+2*j };
+codegen t:is;
+
+# non-unimodular transformation
+#
+is := { [i,j] : 0 <=i<= 4 && 0 <= j<= 6 };
+t := { [i,j] -> [i2,j2] : i2 = 2*i+j && j2 = i+2*j };
+codegen t:is;
+
+# second loop level is degenerated
+#
+is := {[i,j]:1 <= j <= 100 && j = i+4};
+t := {[i,j]->[a,b]: a = i && b = j};
+codegen t:is;
+
+# global variable case 1
+#
+is := { [i] : 19+n = i };
+t:= { [i] -> [j]: j = i };
+codegen t:is;
+
+# global variable case 2
+#
+is := {[i]: i-16 <= n < i && exists (alpha: i = n+1+3*alpha) };
+t := {[i] -> [i] : exists ( alpha : i = 1+n+18alpha)};
+codegen t:is;