This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2021-10-29
Channels
- # aleph (3)
- # announcements (29)
- # babashka (99)
- # beginners (30)
- # calva (46)
- # cider (9)
- # clara (1)
- # cljsrn (4)
- # clojars (10)
- # clojure (41)
- # clojure-dev (4)
- # clojure-europe (45)
- # clojure-nl (3)
- # clojure-norway (13)
- # clojure-uk (5)
- # clojurescript (61)
- # community-development (11)
- # cursive (10)
- # data-science (1)
- # events (1)
- # fulcro (17)
- # graphql (1)
- # gratitude (1)
- # holy-lambda (1)
- # jobs (4)
- # jobs-discuss (5)
- # meander (22)
- # off-topic (50)
- # pedestal (3)
- # re-frame (3)
- # reagent (3)
- # reitit (82)
- # releases (2)
- # rewrite-clj (14)
- # shadow-cljs (3)
- # spacemacs (14)
- # tools-deps (7)
- # xtdb (33)
Hey, I don't want this to go under the radar and I think it's worth everyone's time. noprompt gave me a truly eye opening solution to the problem I posed. https://github.com/noprompt/meander/discussions/216#discussioncomment-1555041
I just contributed (for fun) an implementation based on an explicit state machine here https://github.com/noprompt/meander/discussions/216#discussioncomment-1563336
And with all that explanation, this example might be a bit clearer for people as well. An abstract machine interpreter for the lambda calculus. https://github.com/noprompt/meander/blob/epsilon/examples/cek.clj
It is progressing but I’m no longer pushing to the zeta
branch and I’ve scaled back the amount of time I’m investing in it. After a few different failed iterations to get a unified interface for both compilation and interpretation, I’ve gone back to just having the two separate. All that failed work has come at a cost to my motivation. Plus, working solo gets old after awhile. Compounding all of that has been some really demotivating shit at work.
The project is still important to me — I think about it practically everyday — but I’m low on motivation and help.
To be doubly transparent: I could use a hand. If I need to write down what is needed to complete the next version in the form of tickets, semantics, etc. then I can do that.
Hey this is one of my favorite projects, so I'm more than up to lend a hand. The only issue (which might very well be a deal-breaker if you want to scale down your time investment) is that I don't want to work in solitude - I do that at work already. But, if you want to pair on the weekends, I'm up for it 🙂
Pairing on the weekend is difficult for me right now because my kids are still young and its difficult to block out time for that sort of thing. However, I think I could make room for a monthly meet up to discuss the project, make tickets, etc.
Can you suggest reading material related to the work? Foundational material? You pointed me at SECD and CEK which both have wikipedia articles with handfuls of citations (which is an intimidating starting point). That is an application of meander that I had not considered. My current plan is to try to use it for everything and experience what works and what doesn't. I'm nowhere near being able to contribute ideas or code to the project but I'm sympathetic. I'd like to see myself contribute examples and docs in the future but I'm not making a commitment.
It was less the literature and more my experiences with programming. But if I had to pick something it'd be the literature connected to Small Step Interpreters, and Operational Semantics (connected to the stuff I mentioned about abstract interpreters in the Github discussion). At the time I'd been really interested in programming languages for a while but I had never encountered anything like the CESK machine. I was really blown away that languages could be interpreted that way. That is what sparked me to start on what would eventually become the rewrite
macro.
This was the article that started it: https://matt.might.net/articles/cesk-machines/ Then this paper: https://matt.might.net/papers/vanhorn2010abstract.pdf Then this book: https://mitpress.mit.edu/books/semantics-engineering-plt-redex
Later on, I found out that, in general, I was actually interested in the topic of "term rewriting" and found a lot of inspiration in the languages Maude, TXL, and Stratego. Books on the topic are incredibly dry and, I'll admit, I found some of the material dense and struggled with it. But even if I didn't always grasp everything, I'm confident I came away with the main ideas. Sometimes that required a lot digging around on the internet. Sometimes it just meant retracing my steps until the light went off or I gave up and moved on.
It is progressing but I’m no longer pushing to the zeta
branch and I’ve scaled back the amount of time I’m investing in it. After a few different failed iterations to get a unified interface for both compilation and interpretation, I’ve gone back to just having the two separate. All that failed work has come at a cost to my motivation. Plus, working solo gets old after awhile. Compounding all of that has been some really demotivating shit at work.
The project is still important to me — I think about it practically everyday — but I’m low on motivation and help.
To be totally transparent: the project is not dead.
To be doubly transparent: I could use a hand. If I need to write down what is needed to complete the next version in the form of tickets, semantics, etc. then I can do that.
(m/rewrites
(:doxa/db #:doxa{:db {}})
(m/and
{?t2 {?document {:document/id (m/some ?document-id) ,
:project (m/or [_ (m/some :foo)]
(m/scan [_ :foo]))}}}
{?t1 {?bucket {:opsUnmergedField/id (m/some ?bucket-id) ,
:document (m/or [_ (m/some ?document)]
(m/scan [_ (m/some ?document)]))}}})
true)
why is it not compiling?usually when it returns
Unable to resolve symbol: T__40212 in this context
it means that the order is wrong, but here I cannot come to anythingI've been working on this issue. I figured out where the problem is and am close to fixing.
I just contributed (for fun) an implementation based on an explicit state machine here https://github.com/noprompt/meander/discussions/216#discussioncomment-1563336