Skip to content

Latest commit

 

History

History
248 lines (182 loc) · 10.1 KB

README.md

File metadata and controls

248 lines (182 loc) · 10.1 KB

Substack Discord Shield License

Road to Reality Essays

Welcome to the Road to Reality!

The Road to Reality is an essay series by me, Sam Ritchie. Starting with the basics of Lisp (the Clojure programming language, specifically), we'll build a modern computer algebra system and use that system to explore and simulate gems of modern physics like variational mechanics and general relativity.

The only way to really learn how a machine works is to build one yourself. By the time we're through, you'll understand modern physics with the intuitive ease of a mechanic debugging the drivetrain of a familiar car. You will have built the car, and will be able to drive the car with confidence into the strange country of quantum mechanics, general relativity, chaos theory and phase space.

The essays live at https://reality.mentat.org. Get started reading at the Introduction.

I publish updates on the essays in the "Road to Reality" Substack newsletter. Please subscribe at https://roadtoreality.substack.com.

How can I help?

The Road to Reality essays are part of my larger attempt to build a system for writing and publishing executable textbooks. If you find any of this inspiring or interesting, you can:

  • Subscribe to the newsletter: Substack
  • Join the Discord community: Discord Shield
  • Send me a note at [email protected].

Please consider sponsoring the effort via Github Sponsors, or by signing up for a paid subscription to the "Road to Reality" Substack.

The best thing you can do is riff on and share the essays, and to the extent that you find them inspiring, use them to teach someone else.

How do I read the essays?

There are currently two ways to read the essays:

I strongly believe that work like this should be read in the same environment that I used while writing. You can read a paper book with pen in hand, mark it up and take margin notes; why not do the same with these executable essays?

Each essay is backed by a source code file written in the Clojure programming language. I hope you'll pay the small up-front cost of setting up your computer and downloading the essays (described in the "Running the Essays" section).

The environment has the beautiful property that if you (you!!) change the source code, the entire essay will re-render and incorporate your changes.

So as you read, if you become curious about what a simulation would look like with different initial conditions, or how a satellite might behave if you change its orbit... or if you want to hijack an essay completely and turn it into a programmable calculator, you can do that!

These essays are successful only to the extent that you feel empowered to edit and fiddle with them, and maybe even use the tools to explore and learn on your own.

Why are you writing these?

My work on this project stemmed from my own frustration at the one-way nature of the way I was studying math and physics. When I read books like Sussman and Wisdom's "Structure and Interpretation of Classical Mechanics", I felt like I was building new machinery inside my head that let me see new patterns in the world that I hadn't been able to see before.

I wanted to share what I'd learned, but the only language available was symbol-heavy and inscrutable to my friends. I couldn't show anyone what I could now see in my head.

My work on the Emmy computer algebra system and the other projects described on the "Tools" page is my attempt to make tangible and accessible some of the discoveries and progression that humans have achieved in math and physics over the last 2,000 years in a way that feels less like torture and more like exploring a beautiful, strange series of simulations and video games.

Put more simply: An executable Wikipedia / Digital Museum full of interactive simulations demonstrating our best understanding of the rules reality follows should exist. No one else seemed to be building it, so I decided to start poking around.

Running / Editing the Essays

To run the essays, you'll need to complete the following steps:

  • Download the essays to your computer
  • Set up your computer to run the essays
  • Choose a programming "text editor" that you'll use to edit the files
  • Run the program that builds the essays....
  • Play!

if you get stuck at any point, write up where you're stuck on this form and I'll help you get going.

Note

I know that this is a fairly annoying sequence of steps! I will simplify this process over time. Eventually you'll be able to read and edit the essays fully in the browser at https://reality.mentat.org. This is where we are now, not where we'll end up.

Download the Essays

Open your terminal and run the following commands:

cd ~/Documents # or pick your location
git clone [email protected]:mentat-collective/road-to-reality.git
cd road-to-reality

The essays live inside of the essays folder.

If you don't know what this means, install GitHub Desktop, create an account or sign in, and choose "Clone a Repository from the Internet". Type the phrase "mentat road", select the first item in the list and click "Clone".

Dependencies

Install the following dependencies (follow the hyperlinks for install instructions):

You'll also need node installed, preferably via nvm.

Now, in the road-to-reality directory you entered above, run the following command to check your installation and see all of the Babashka Tasks declared in the bb.edn file:

bb tasks

Choosing an Editor

The essays are rendered using the Clerk notebook system.

Clerk is a program that watches Clojure source code files and renders them in a browser window. To use this workflow you'll need to choose your own text editor to edit these source files.

Here are links to guides for the most popular editors and Clojure plugins:

If this is your first time using Clojure, I recommend Calva for Visual Studio Code.

Once you've chosen an editor, open the road-to-reality project in the editor and navigate to the essays/reality/introduction.clj file.

Editing the Essays

Back at your terminal, run the following command:

bb clerk-watch

Eventually a browser window will appear, pointing to http://localhost:7777. If you close the window by accident this link will get you back to the essay view.

Now edit any line in introduction.clj -- maybe add an exclamation point somewhere? -- and save the file. If the browser display updates to the introduction essay with your change, you're now in business! Read in the browser pane, and edit any example you find in the essays. A simple edit-and-save should cause everything to update.

REPL-Based Exploration

Alternatively, instead of bb clerk-watch follow your editor's instructions (see "Choosing an Editor" above) to start a Clojure REPL, and then run (user/serve!).

Running the essays this way will let you use the Clojure REPL to explore.

To show or reload a particular notebook, call nextjournal.clerk/show! with the file's path as argument. The Book of Clerk has good instructions on how to configure your editor for this.

You can try this without any editor support by starting a REPL from the command line:

bb repl

Then start the server:

(user/serve!)

To show a file, pass it to clerk/show!:

(nextjournal.clerk/show! "essays/reality/introduction.md")

License

Copyright © 2022-2023 Sam Ritchie.

Distributed under the MIT License. See LICENSE.