aboutsummaryrefslogtreecommitdiff
path: root/symbolic/optimizations.py
diff options
context:
space:
mode:
authorAdrian Kummerlaender2019-06-18 14:47:13 +0200
committerAdrian Kummerlaender2019-06-18 18:04:26 +0200
commit804e15d65e32479a476ef212238c25ada4865e3f (patch)
tree93350ff9462d6ed52ce68df7b061fa70eb7f1199 /symbolic/optimizations.py
parentb178e9b0e70e2b85ad7ba82d6afff1464cc27c51 (diff)
downloadsymlbm_playground-804e15d65e32479a476ef212238c25ada4865e3f.tar
symlbm_playground-804e15d65e32479a476ef212238c25ada4865e3f.tar.gz
symlbm_playground-804e15d65e32479a476ef212238c25ada4865e3f.tar.bz2
symlbm_playground-804e15d65e32479a476ef212238c25ada4865e3f.tar.lz
symlbm_playground-804e15d65e32479a476ef212238c25ada4865e3f.tar.xz
symlbm_playground-804e15d65e32479a476ef212238c25ada4865e3f.tar.zst
symlbm_playground-804e15d65e32479a476ef212238c25ada4865e3f.zip
Expand square expressions
Yields another ~5-10 MLUPS in the simple D2Q9 example. Now averaging at ~840 MLUPS for D2Q9 and ~ 400 MLUPS for D3Q19 on a K2200.
Diffstat (limited to 'symbolic/optimizations.py')
-rw-r--r--symbolic/optimizations.py10
1 files changed, 10 insertions, 0 deletions
diff --git a/symbolic/optimizations.py b/symbolic/optimizations.py
new file mode 100644
index 0000000..93dad09
--- /dev/null
+++ b/symbolic/optimizations.py
@@ -0,0 +1,10 @@
+from sympy import *
+
+from sympy.codegen.rewriting import ReplaceOptim
+
+expand_square = ReplaceOptim(
+ lambda e: e.is_Pow and e.exp.is_integer and e.exp == 2,
+ lambda p: UnevaluatedExpr(Mul(p.base, p.base, evaluate = False))
+)
+
+custom = [ (expand_square, expand_square) ] + cse_main.basic_optimizations