recursion-schemes
Generalized bananas, lenses and barbed wire (by ekmett)
advent
Solutions to https://adventofcode.com/ (by tsenart)
recursion-schemes | advent | |
---|---|---|
20 | 17 | |
335 | 5 | |
0.3% | - | |
4.3 | 6.5 | |
22 days ago | 5 months ago | |
Haskell | Go | |
BSD 2-clause "Simplified" License | - |
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
recursion-schemes
Posts with mentions or reviews of recursion-schemes.
We have used some of these posts to build our list of alternatives
and similar projects. The last one was on 2023-12-05.
-
-❄️- 2023 Day 4 Solutions -❄️-
Reasonably proud of my part 2 solution, although would like to try using a recursion scheme rather than unstructured recursion:
-
Interactive animations
Yeah, that project is pretty much at the bottom of my list, unfortunately. My top projects these days are mgmt, klister, recursion-schemes, and hint... And that's already too much!
-
Science of Recursion
In a programming context, recursion schemes can be used to write recursive (or corecursive) functions, by automating/abstracting away the common boilerplate part of actually doing the recursion. They take the form of polymorphic higher-order functions, which can be imported from a library like this classic one.
-
Is there a way to avoid call overhead?
Maybe I didn't link the best post. It is unfortunately the only one I know that uses Rust. If you are able to read Haskell, the documentation for the recursion-schemes package might be a better resource?
-
Ah yes I love arrays with a length of infinity!!!
Writing something as a type of fold over an infinite sequence is nicer than using recursion directly in my opinion. See: https://hackage.haskell.org/package/recursion-schemes
-
Tips on mastering recursion and trees and shit?
Consider recursion schemes! It let's you separate the logic of how your recursion is structured on your data, and the logic of what you're doing on each recursion stage. So e.g. you can write the core logic of a recursive linked list summation as just fun x accum -> x + accum, and then you just find the appropriate recursion scheme to pipe the list values into x and handle recursing to build accum (a catamorphism in this case)
-
So you come across an undocumented library…
It's a pretty complicated bug, documented in details at https://github.com/recursion-schemes/recursion-schemes/issues/50
-
Beautiful ideas in programming: generators and continuations
It’s also trivial and easy in Haskell — you just need an instance of `Foldable` or `Traversable` on your collection, and then you can fold or traverse it in a configurable way. Or for recursive structures, use https://hackage.haskell.org/package/recursion-schemes. Or even just pass a traversal function as an argument for maximum flexibility.
-
fromMaybe is Just a fold
https://hackage.haskell.org/package/recursion-schemes is the "normal" library for this type of generalized folding. It even contains Base instances for Maybe and Either.
-
Annotation via anamorphism?
I've been working on a system which uses recursion-schemes to annotate a recursive type. The annotated tree itself is pretty simple; at each level, we pair the annotation with the base functor, or
advent
Posts with mentions or reviews of advent.
We have used some of these posts to build our list of alternatives
and similar projects. The last one was on 2023-12-05.
- -❄️- 2023 Day 5 Solutions -❄️-
-
-❄️- 2023 Day 4 Solutions -❄️-
No heap allocations: https://github.com/tsenart/advent/blob/master/2023/4
- A Neat XOR Trick
-
-🎄- 2022 Day 12 Solutions -🎄-
~200 microseconds runtime Go solutions based on BFS that plot the path in the terminal: https://github.com/tsenart/advent/tree/master/2022/12
-
Advent Of Code 2022 golang solutions
Also doing it in Go: https://github.com/tsenart/advent
- -🎄- 2022 Day 9 Solutions -🎄-
-
[2022 Day 8] Visualization of both parts on a intuitive grid
Nice. I did that but traversing all directions in each inner loop iteration: https://github.com/tsenart/advent/blob/master/2022/8/one.go
- -🎄- 2022 Day 8 Solutions -🎄-
- -🎄- 2022 Day 7 Solutions -🎄-
- -🎄- 2022 Day 6 Solutions -🎄-
What are some alternatives?
When comparing recursion-schemes and advent you can also consider the following projects:
distributed-process-platform - DEPRECATED (Cloud Haskell Platform) in favor of distributed-process-extras, distributed-process-async, distributed-process-client-server, distributed-process-registry, distributed-process-supervisor, distributed-process-task and distributed-process-execution
adventOfCode2022
record - Anonymous records
advent-of-code-2022 - 🎄 My Advent of Code solutions in Rust. http://adventofcode.com/2022
unliftio - The MonadUnliftIO typeclass for unlifting monads to IO
aoc2022
machines - Networks of composable stream transducers
AdventOfCode2022
chr-core - Constraint Handling Rules
MonkeyAOC
pipes-core - Compositional pipelines
AdventOfCode2022
recursion-schemes vs distributed-process-platform
advent vs adventOfCode2022
recursion-schemes vs record
advent vs advent-of-code-2022
recursion-schemes vs unliftio
advent vs aoc2022
recursion-schemes vs machines
advent vs AdventOfCode2022
recursion-schemes vs chr-core
advent vs MonkeyAOC
recursion-schemes vs pipes-core
advent vs AdventOfCode2022