aboutsummaryrefslogtreecommitdiff
path: root/src/Example.hs
diff options
context:
space:
mode:
authorTom Smeding <tom@tomsmeding.com>2025-10-23 23:43:54 +0200
committerTom Smeding <tom@tomsmeding.com>2025-10-23 23:43:54 +0200
commit1adad63b14aa8d13295fb0d68fbdc8ab988775b2 (patch)
tree3310a49b33e6996a8470d6ec053ecced0bc0dae3 /src/Example.hs
parentc50aecbb209bb99da074b6c6911b672d0f1d1388 (diff)
Add uniform-tree test and benchmark
We need an optimisation that detects replicate-like behaviour and turns it into actual replicates, which should then be fused away. The problem is exhibited by this function exUniformFree.
Diffstat (limited to 'src/Example.hs')
-rw-r--r--src/Example.hs11
1 files changed, 11 insertions, 0 deletions
diff --git a/src/Example.hs b/src/Example.hs
index 1784a48..bccc8de 100644
--- a/src/Example.hs
+++ b/src/Example.hs
@@ -167,3 +167,14 @@ neuralGo =
(Value dinput_2 `SCons` Value dlay3_2 `SCons` Value dlay2_2 `SCons` Value dlay1_2 `SCons` SNil) = drevByFwdInterp knownEnv neural argument 1.0
in trace (ppExpr knownEnv revderiv) $
(primal, (dlay1_1, dlay2_1, dlay3_1, dinput_1), (dlay1_2, dlay2_2, dlay3_2, dinput_2))
+
+-- The build body uses free variables in a non-linear way, so their primal
+-- values are required in the dual of the build. Thus, compositionally, they
+-- are stored in the tape from each individual lambda invocation. This results
+-- in n copies of y and z, where only one copy would have sufficed.
+exUniformFree :: Ex '[R, I64] R
+exUniformFree = fromNamed $ lambda #n $ lambda #x $ body $
+ let_ #y (#x * 2) $
+ let_ #z (#x * 3) $
+ idx0 $ sum1i $
+ build1 #n $ #i :-> #y * #z + toFloat_ #i