« BackRacket v9.1blog.racket-lang.orgSubmitted by azhenley 3 hours ago
  • coffeemug 2 hours ago

    I've been using Racket to work through The Little Learner[1] and it's been a good experience. You need minimal Racket to work through the book (lambda, let, define, map; I think that's about it). But I branched out to learn more about the language and the standard library, and it's a fun and surprisingly powerful system to explore.

    The biggest downside of Racket is that you can't build up your environment incrementally the way you can with Common Lisp/Sly. When you change anything in your source you reload REPL state from scratch. After CL it feels incredibly limiting in a Lisp. Incremental buildup is so valuable, if I wanted to do any Lisp work again I'd reach for CL before Racket just for this reason.

    BTW, the book is _great_. Quick, easy to get through, very easy to understand, and teaches you everything from soup to nuts. If you're familiar with lisps you can get through the book in two weeks. It's then easy to get into any deep learning tutorial or project you want, or even start implementing some papers. The book manages not to water down the material despite not using any math at all. Although if you know some linear algebra or multivariable calculus you'll appreciate the beauty of the field more.

    [1] https://www.thelittlelearner.com/

    • meken an hour ago

      > The biggest downside of Racket is that you can't build up your environment incrementally the way you can with Common Lisp/Sly. When you change anything in your source you reload REPL state from scratch.

      I don’t quite understand… I’m using Racket in emacs/SLIME and I can eval-last-sexp, regions, etc.

      • coffeemug an hour ago

        Ah, I'm using racketmode which doesn't support live state buildup (and the builtin GUI doesn't either). What exactly is your setup? SLIME only has a Common Lisp backend, it doesn't support Racket to my knowledge.

    • behnamoh an hour ago

      > The biggest downside of Racket is that you can't build up your environment incrementally the way you can with Common Lisp/Sly. When you change anything in your source you reload REPL state from scratch.

      I think no Lisp is a "true" Lisp if it doesn't provide two critical components of the Lisp experience:

      - Live Images

      - REPL-driven development

      That's why Clojure/Racket and even Scheme are Lisp-y but not a true Lisp. The only true Lisp languages I've found are CL and Janet.

      • packetlost an hour ago

        Is this not ultimately a late-binding issue? Maybe I'm missing something, but I've absolutely been able to incrementally build up an environment without resetting using nrepl and Clojure

    • meken 2 hours ago

      I learned recently that Racket is an accepted language on LeetCode, which solved the problem “when am I ever going to write lisp in real life…” for me. It’s provided a great excuse.

      I have really been enjoying writing it! Paredit and SLIME are addictive.

      • behnamoh an hour ago

        > LeetCode

        > ...real life...

            (≠ "LeetCode" "real life")
        • meken 20 minutes ago

          For sure. I just meant having some motivating purpose to write Racket.