austin-sbst
algebra-driven-design
austin-sbst | algebra-driven-design | |
---|---|---|
1 | 11 | |
7 | 131 | |
- | - | |
0.0 | 4.3 | |
about 9 years ago | 6 months ago | |
OCaml | Haskell | |
- | BSD 3-clause "New" or "Revised" 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.
austin-sbst
algebra-driven-design
- What are some useful techniques for designing in functional languages?
-
Rust for projects that demand OOP type programming
You might want to read on Algebra-Driven Design and Data Oriented Design. If you are greedy, both books were pirated.
-
Does anyone use formal methods to validate the behaviour of programs/software at their job?
I would like to do this more. At the moment I don't do formal verification. However, I often borrow methodology from the excellent book Algebra-Driven Design (text available on GitHub but support the author if you find it useful!) when designing systems. This means I define algebraic data types to describe the program and the laws that relate the different types, and use that to guide implementation in a language that doesn't support ADTs.
- Best books for Haskell
-
Do you feel static types have "won the war", so to speak?
Their approach might be to express their business logic as a carefully selected collection of types and laws, as described in Algebra-Driven Design (the full text is available on GitHub, please support the author if you find it useful though). I recommend this book to everyone because, even if you don't use this approach to design your programs, it's an excellent way to think about problems and better understand the problem space.
-
Can someone message me explaining category theory and representation theory? I’m trying to choose a topic for independent study and need some help.
If you have an interest in computer science, category theory is very useful there. Here's a good book on the topic (Algebra-Driven Design, by Sandy Maguire).
-
Does anybody know a simple algorithm for generating unit tests given a function's code?
This reminds me of QuickSpec (different from QuickCheck) in Haskell. It takes Haskell code and finds the Mathematical laws that the code supports. It does this using a sort of smart random search. I learned about this as part of the Algebra Driven Design book.
- Source material for Algebra-Driven Design now available!
-
Advice on designing algebras
Sorry probably worth pointing out that I'm not referring to an Algebra in the pure math sense. I'm more referring to specifying algebraic laws that an API would have to satisfy as talked about in this book https://leanpub.com/algebra-driven-design.
What are some alternatives?
EvoMaster - The first open-source AI-driven tool for automatically generating system-level test cases (also known as fuzzing) for web/enterprise applications. Currently targeting whitebox and blackbox testing of Web APIs, like REST, GraphQL and RPC (e.g., gRPC and Thrift).
learn-you-a-haskell - “Learn You a Haskell for Great Good!” by Miran Lipovača
methods2test - methods2test is a supervised dataset consisting of Test Cases and their corresponding Focal Methods from a set of Java software repositories
Agda - Agda is a dependently typed programming language / interactive theorem prover.
tcases - A model-based test case generator
pynguin - The PYthoN General UnIt Test geNerator is a test-generation tool for Python
FsCheck - Random Testing for .NET
sorbet - A fast, powerful type checker designed for Ruby