| Commit message (Collapse) | Author | Age | |
|---|---|---|---|
| * | Some more primitive operators | Tom Smeding | 2024-11-09 | 
| | | |||
| * | WIP maximum/minimum | Tom Smeding | 2024-11-08 | 
| | | |||
| * | Custom derivatives | Tom Smeding | 2024-11-08 | 
| | | |||
| * | Remove build1 | Tom Smeding | 2024-11-07 | 
| | | |||
| * | Benchmark | Tom Smeding | 2024-11-07 | 
| | | |||
| * | Generate EOneHot in D[EIdx] | Tom Smeding | 2024-11-05 | 
| | | | | | | | This generates a one-hot for the zero-dimensional inner array because indexing one level further to the actual element is too difficult. But this should simplify away fine. | ||
| * | WIP EOneHot | Tom Smeding | 2024-11-04 | 
| | | |||
| * | Store only on tape what's used in the dual | Tom Smeding | 2024-10-29 | 
| | | |||
| * | WIP preserve only subset of D0 bindings in dual (...) | Tom Smeding | 2024-10-27 | 
| | | | | | | | | | | | | | | | | The point of this is to ensure that when an expression occurs in a Build, then the parts of D0 that are only there to make sharing work out for D1 are not laboriously taped in an array and preserved for D2, only for D2 to ignore them. However, while the subtape machinery is a good first step, this is not everything: the current Build translation makes a Build for the (elementwise) tape and separately a build for the primal. Because the primal _does_ generally need the subtaped-away stuff, we can't just not tape those. TODO: figure out how to resolve this / what the next step is. | ||
| * | Fix EIdx derivative | Tom Smeding | 2024-10-26 | 
| | | |||
| * | Debugging | Tom Smeding | 2024-10-26 | 
| | | |||
| * | Fix interpreter bug | Tom Smeding | 2024-10-22 | 
| | | |||
| * | Less warnings | Tom Smeding | 2024-10-22 | 
| | | |||
| * | Differentiate Replicate | Tom Smeding | 2024-10-22 | 
| | | |||
| * | Tests | Tom Smeding | 2024-10-21 | 
| | | |||
| * | Towards a test suite | Tom Smeding | 2024-10-07 | 
| | | |||
| * | Reverse-by-forward, and checking neural (it's wrong) | Tom Smeding | 2024-10-01 | 
| | | |||
| * | Test neural | Tom Smeding | 2024-09-25 | 
| | | |||
| * | WIP better zero/plus, fixing Accum (...) | Tom Smeding | 2024-09-13 | 
| | | | | | | | | | | | | | | The accumulator implementation was wrong because it forgot (in accumAdd) to take into account that values may be variably-sized. Furthermore, it was also complexity-inefficient because it did not build up a sparse value. Thus let's go for the Haskell-interpreter-equivalent of what a real, fast, compiled implementation would do: just a tree with mutable variables. In practice one can decide to indeed flatten parts of that tree, i.e. using a tree representation for nested pairs is bad, but that should have been done _before_ execution and for _all_ occurrences of that type fragment, not live at runtime by the accumulator implementation. | ||
| * | Towards neural | Tom Smeding | 2024-09-12 | 
| | | |||
| * | Interpreter, some operations | Tom Smeding | 2024-09-12 | 
| | | |||
| * | Generic accumulators | Tom Smeding | 2024-09-05 | 
| | | |||
| * | WIP | Tom Smeding | 2024-09-04 | 
| | | |||
| * | Some work | Tom Smeding | 2024-09-03 | 
| | | |||
| * | Inching towards drev of build | Tom Smeding | 2024-09-03 | 
| | | |||
| * | accumPromote | Tom Smeding | 2024-09-02 | 
| | | |||
| * | Code cleanup, and OverloadedLabels for LSeg | Tom Smeding | 2024-09-02 | 
| | | |||
| * | Autoweak! | Tom Smeding | 2024-09-02 | 
| | | |||
| * | WIP autoWeak | Tom Smeding | 2024-09-02 | 
| | | |||
| * | WIP Build1 | Tom Smeding | 2024-08-30 | 
| | | |||
| * | Migrate to accumulators (mostly removing EVM code) | Tom Smeding | 2024-08-30 | 
| | | |||
| * | Generalise freezeRet a little bit | Tom Smeding | 2024-08-29 | 
| | | |||
| * | Less default case | Tom Smeding | 2024-01-27 | 
| | | |||
| * | Linear-time tape reconstruction | Tom Smeding | 2024-01-26 | 
| | | | | | A tutorial of the method here: https://play.haskell.org/saved/uHuGLfHZ | ||
| * | Embrace the PartialTypeSignatures | Tom Smeding | 2024-01-25 | 
| | | |||
| * | Finish rewrite | Tom Smeding | 2024-01-25 | 
| | | |||
| * | Getting further | Tom Smeding | 2024-01-25 | 
| | | |||
| * | More stuff | Tom Smeding | 2024-01-25 | 
| | | |||
| * | WIP rewrite code transform typing | Tom Smeding | 2024-01-24 | 
| | | |||
| * | Better modularity in subenv stuff | Tom Smeding | 2023-09-22 | 
| | | |||
| * | WIP in merge mode only return free variables | Tom Smeding | 2023-09-21 | 
| | | | | | The code typechecks and may well work, but is untested. | ||
| * | Storage policy (accum / merge) | Tom Smeding | 2023-09-21 | 
| | | |||
| * | WIP mixed environment description | Tom Smeding | 2023-09-21 | 
| | | |||
| * | Examples with conditionals | Tom Smeding | 2023-09-20 | 
| | | |||
| * | Pretty print | Tom Smeding | 2023-09-16 | 
| | | |||
| * | CHAD ops | Tom Smeding | 2023-09-16 | 
| | | |||
| * | CHAD case | Tom Smeding | 2023-09-16 | 
| | | |||
| * | CHAD let | Tom Smeding | 2023-09-10 | 
| | | |||
| * | Initial | Tom Smeding | 2023-09-10 | 
