Readings
1 Books, papers, and documentation
These readings cover many of the ideas from this course. Those listed in bold are the most relevant, while the others offer more advanced techniques and applications.
1.1 On the big idea
"A Programmable Programming Language" https://cacm.acm.org/research/a-programmable-programming-language/
Why language-oriented programming? Why Racket?"https://beautifulracket.com/appendix/why-lop-why-racket.html
"When and How to Develop Domain-Specific Languages" https://dl.acm.org/doi/pdf/10.1145/1118890.1118892
1.2 On embedded DSLs
The academic literature on embedded domain specific langauges mostly employs Haskell. We will apply some of these ideas in Racket in the early part of the course.
"Modular Domain Specific Languages and Tools" https://staff.um.edu.mt/afra1/seminar/ModularDSL.pdf
"Folding Domain-Specific Languages: Deep and Shallow Embeddings" https://www.cs.ox.ac.uk/jeremy.gibbons/publications/embedding.pdf
"Higher-Order Functions for Parsing" https://nottingham-repository.worktribe.com/preview/1024973/parsing.pdf
"Modeling Interactive 3D and Multimedia Animation with an Embedded Language" https://www.usenix.org/legacy/publications/library/proceedings/dsl97/full_papers/elliott/elliott.pdf
"Domain Specific Embedded Compilers" https://dl.acm.org/doi/pdf/10.1145/331960.331977
"Polymorphic Embedding of DSLs" https://dl.acm.org/doi/pdf/10.1145/1449913.1449935
1.3 On writing Scheme and Racket macros
"Programming Languages: Application and Interpretation V3", the "Syntactic Sugar" section https://www.plai.org/3/2/PLAI%20Version%203.2.2%20electronic.pdf
The Racket documentation, ’Macros’ section https://docs.racket-lang.org/guide/macros.html
"Fear of Macros" https://www.greghendershott.com/fear-of-macros/
- "The Scheme Programming Language" chapters on macros:
"Macros and Languages in Racket, V2" https://rmculpepper.github.io/malr/v2/
2019 Racket Summer School lecture notes https://school.racket-lang.org/2019/plan/index.html
1.4 On building DSLs with macros
The syntax-spec documentation and tutorials https://docs.racket-lang.org/syntax-spec-v2/index.html
"Herbarium Racketensis: A Stroll through the Woods" http://users.eecs.northwestern.edu/~sfq833/resources/papers/herbarium_racketensis_2017.pdf
"Super 8 Languages for Making Movies (Functional Pearl)" https://www.khoury.northeastern.edu/home/stchang/pubs/acm-icfp17.pdf
"Compiled, Extensible, Multi-language DSLs" https://dl.acm.org/doi/10.1145/3674627
"Beautiful Racket" https://beautifulracket.com/
"The Anatomy of a Loop" https://www.khoury.northeastern.edu/home/shivers/papers/loop.pdf
1.5 On the more technical aspects of Racket’s macro system
"Languages as Libraries" https://www2.ccs.neu.edu/racket/pubs/pldi11-thacff.pdf
"Composable and Compilable Macros" https://www-old.cs.utah.edu/plt/publications/macromod.pdf
"Binding as Sets of Scopes" https://users.cs.utah.edu/plt/scope-sets/
"Fortifying Macros" https://www2.ccs.neu.edu/racket/pubs/c-jfp12.pdf
"Macros that Work Together" https://www-old.cs.utah.edu/plt/publications/jfp12-draft-fcdf.pdf
2 DSLs in the wild
You might take inspiration from these DSLs for your project.
DSL | Domain | Host Language | Domain-specific advantage |
Build automation | Scala | Declarative build definitions with compile-time checks | |
Database queries | Scala | Type-safe SQL abstractions with static checks | |
Hardware design | Scala | Parametric circuit generation with type checks | |
Program verification | Scala | Solver-aided verification of functional correctness | |
Web APIs | Scala | Declarative routing with compile-time safety | |
Web APIs | Rust | Declarative routing with macro-based type safety | |
Serialization | Rust | Macro-driven derive for efficient serialization | |
BDD testing | Python | Natural-language test scenarios with domain readability | |
Database queries | Python | SQL-like queries with runtime checks and composability | |
Geospatial analysis | Python | Geometric operations with domain-specialized data structures | |
Machine learning | Python | Dynamic graphs and GPU-accelerated execution | |
Machine learning | Python | Graph-based ML computations with optimized execution | |
Meteorology | Python | Prebuilt meteorological functions with domain syntax | |
State machines | Python | Declarative state machines with visualizable transitions | |
Testing | Python | DSL-like tests with introspection and fixtures | |
Workflow management | Python | Declarative workflows with automatic parallelization and caching | |
PDE solving | Python | Symbolic PDEs with automatic code generation | |
Symbolic mathematics | Python | Symbolic computations with domain syntax | |
Probabilistic programming | Python | Compositional Bayesian models with MCMC inference | |
Climate modeling | Julia | Modular integrated assessment models with domain abstractions | |
Symbolic modeling | Julia | Symbolic computations with optimized code generation | |
Infrastructure as code | JavaScript | Type-safe infrastructure definitions with compile-time checks | |
API queries | JavaScript | Schema-driven queries with static validation | |
CSS generation | JavaScript | CSS-in-JS with dynamic props and tooling | |
Data visualization | JavaScript | Declarative visualizations with data-driven transformations | |
Synchronous reactive programming | JavaScript | Synchronous concurrency with deterministic reactive semantics | |
Data visualization | JavaScript | Schema-driven charts with automatic encodings | |
Business rules | Java | Readable rule-based logic with static analysis | |
Logic programming | Java | Datalog-based logic with static type checking | |
Database queries | Java | Typesafe SQL queries with compile-time checks | |
Graph queries | Java | Traversal-based graph queries with optimizations | |
Integration patterns | Java | Fluent routing and mediation with type checks | |
Reactive streams | Java | Asynchronous pipelines with fluent reactive operators | |
Document generation | Haskell | Type-safe LaTeX generation with composable abstractions | |
Runtime verification | Haskell | Stream-based temporal checks with compile-time assurances | |
Functional reactive programming | Haskell | Continuous-time FRP with modular signal functions | |
GPU computing | Haskell | Parallel computations to efficient GPU code | |
GPU computing | Haskell | Type-safe 3D pipelines with static checks | |
Music composition | Haskell | Functional music composition with type-safe abstractions | |
Parsing | Haskell | Pure combinators with static guarantees | |
Probabilistic programming | Haskell | Monadic probabilistic models with inference capabilities | |
Web APIs | Haskell | Type-level API specification with static enforcement | |
CSS generation | Clojure | Programmatic CSS with variables and macros | |
Data manipulation | Clojure | Declarative transformations with composability | |
Database queries | Clojure | Temporal Datalog queries with immutable history | |
HTML templating | Clojure | HTML as data structures with macros | |
Logic programming | Clojure | Relational logic with unification and constraints | |
Parsing | Clojure | BNF-like grammar directly in code | |
Parsing | F# | Composable parser combinators with strong static guarantees | |
Database queries | C# | Integrated queries with static checks | |
Distributed systems | Ruby | Declarative logic for eventually consistent distributed computations | |
Image processing | C++ | Decoupled scheduling with performance optimizations |