fp-ts
Our great sponsors
fp-ts | AdventOfCode2021 | |
---|---|---|
97 | 12 | |
10,452 | 1 | |
- | - | |
7.5 | 2.6 | |
about 1 month ago | over 2 years ago | |
TypeScript | Perl | |
MIT License | - |
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.
fp-ts
-
From a Lorry Driver to Ruby on Rails Developer at 38
I think itβs great that functional programming is making its way into traditional imperative languages - even JavaScript (I recently came across https://gcanti.github.io/fp-ts/ as a pretty extreme example)
Elixir/Erlang has function-level pattern matching, which I really like. Iβve yet to see it anywhere else, though my understanding is it came from Prolog.
-
Type-Safe Printf() in TypeScript
While I certainly agree, I've found that this is often an indication of too-complex an architecture, and a fundamental re-think being necessary. I've had projects that depend on [fp-ts], which end up incredibly generic-heavy, but still make it entirely through a typecheck(not build- typescript's just worse at that than other tools like esbuild) in seconds-at-worse.
Obviously depends on your organization/project/application, but I do like these things as complexity-smells.
[fp-ts]: https://gcanti.github.io/fp-ts/
-
Introducing fp-utils a functional utility library for Deno / Node
Unlike more comprehensive functional libraries like fp-ts, each module can be imported and resolved separately. If you just need options, simply add the option module and you're good to go.
-
Blog post: graphs and monads with Typescript
While it's quite abstract, I believe it may be useful to those of you who is interested to learn more about functional programming [in Typescript] and also get more intuition on diverse programming ideas. I use fp-ts as a functional programming library there.
-
Functional Programming Library for Golang by IBM
The library for TypeScript that this is influenced by is here:
https://github.com/gcanti/fp-ts
Interesting how both languages with this library converge to a similar syntax, due to heavy use of functions.
-
Is Scala worth learning in 2023?
Learn something that pays the bill first - nowadays it's Golang/Rust react/typescript. Then you can try some pure fp libs like fp-ts and fp-core.rs, and look through existing scala cats docs. If you'll feel bad about it - that's totally fine and expectable, fp takes a paradigm shift and not that many dev able to shift their brains way of thought due to basic psychological rigidity) (inability to change habits and to modify concepts/attitudes once developed). And that's purely a staffing and management issue - folks hired randoms out of the blue, and called 'em a team.
-
Application Bootstrapping with fp-ts
fp-ts, a library that caters to functional programming in TypeScript, comes with some micro-abstractions that already solve a few of our needs.
-
What are some strategies for ensuring correctness and fewer errors in dynamically typed languages?
Also, don't underestimate how powerful TypeScript can be in capable hands (namely Giulio Canti's). Check out fp-ts, for instance.
-
Use Pure Functions to understand functional programming
You are able to type it using function overloads, an example can be found here - link, line 236.
-
Error Handling Patterns
looks like more ergonomic/focused version of fp-ts[1]
[1] https://gcanti.github.io/fp-ts/
AdventOfCode2021
-
-π- 2021 Day 18 Solutions -π-
Full program on GitHub.
-
-π- 2021 Day 15 Solutions -π-
Full program including code to deal with heaps, on GitHub.
-
[2021 Day 11 (Part 2)] What input takes the most steps to synchronize?
Program I used for the above results
-
-π- 2021 Day 8 Solutions -π-
See my solution on GitHub.
-
Day 6 Proof of Correctness
Note also that you can solve this without a complexity dependency on n. Most solutions I have seen, including mine run in time O(tD), where t is the maximum value of a timer, and D the number of generation, requiring O(t) memory. (This is assuming we can do the required arithmetic operations in constant time, and each numbers require a fixed around of memory storage; if the number of fish gets huge, throw in an additional log n in the complexities, where n is the number of fish on the final day).
-
-π- 2021 Day 6 Solutions -π-
Based on my matrix exponentiation solution, here is a closed-form solution:
-
How do I read today's input ? Part 1
In my Perl solution of today (I assume, you mean 2021, Day 4), I read stuff in paragraph mode ($/ = "") which makes Perl split input on 2 or more newlines.
-
2021 Day #4 (Part 1) [Native Python ONLY] - Conceptual Guidance?
I considered doing that for my (Perl) solution, but given the cards are small, that seemed overkill.
-
-π- 2021 Day 4 Solutions -π-
Python implementation on GitHub
What are some alternatives?
effect - A fully-fledged functional effect system for TypeScript with a rich standard library
Elixir - Elixir is a dynamic, functional language for building scalable and maintainable applications
ramda - :ram: Practical functional Javascript
Advent-of-code - My solutions of adventofcode.com
proposal-pattern-matching - Pattern matching syntax for ECMAScript
Advent_of_Code_2021_Solutions_Java - Personal AoC/2021 Solutions in Java
purescript - A strongly-typed language that compiles to JavaScript
adventofcode - Advent of Code solutions of 2015, 2016, 2017, 2018, 2019, 2020, 2021, 2022 and 2023 in Scala
io-ts - Runtime type system for IO decoding/encoding
adventofcode - Advent of Code challenge solutions
TypeScript - TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
adventofcode - Solutions for problems from AdventOfCode.com