Skip to content

Latest commit

 

History

History
39 lines (32 loc) · 1009 Bytes

README.md

File metadata and controls

39 lines (32 loc) · 1009 Bytes

lambdagrad

Automatic gradients in ~70 lines of Haskell

Load the Engine module:

$ ghci
GHCi, version 8.10.7: https://www.haskell.org/ghc/  :? for help
Prelude> :l Engine
[1 of 2] Compiling Data             ( Data.hs, interpreted )
[2 of 2] Compiling Engine           ( Engine.hs, interpreted )
Ok, two modules loaded.

Use val to creat computational graphs:

*Engine> expression = ((val 0.5) + (val 3)) ** 2
*Engine> expression
InnerNode Pow 12.25 0.0 (InnerNode Plus 3.5 0.0 (Leaf 0.5 0.0) (Leaf 3.0 0.0)) (Leaf 2.0 0.0)

Use backward to compute gradients:

*Engine> backward expression
InnerNode Pow 12.25 1.0 (InnerNode Plus 3.5 7.0 (Leaf 0.5 7.0) (Leaf 3.0 7.0)) (Leaf 2.0 0.0)

Use getLeafs to get leaf node of the computational graph:

*Engine> getLeafs $ backward expression
[Leaf 0.5 7.0,Leaf 3.0 7.0,Leaf 2.0 0.0]

And gradient to extract their gradients:

*Engine> map gradient (getLeafs $ backward expression)
[7.0,7.0,0.0]