Back to News
Advertisement
Advertisement

⚑ Community Insights

Discussion Sentiment

70% Positive

Analyzed from 525 words in the discussion.

Trending Topics

#goto#psychosis#function#transducers#return#cps#continuations#database#relational#algebra

Discussion (18 Comments)Read Original on HackerNews

gavinrayβ€’about 5 hours ago

  > "Suppose you want to write a database. You'd probably start by implementing relational algebra operators β€” projection, filter, join, etc. The easy way is to implement them as functions that take in tables and return tables, and assemble them into a larger expression. That was how Prela worked in its first incarnation. The code was clean, but it was hella slow! Which was not surprising, because every operator materialized every intermediate result. "
This is one of the LAST things you do when writing a database.

DB development starts with the storage engine, file manager, buffer pool (page cache), and page access methods (heaps/indices) which are binary buffer views. Then, you add the transaction manager, the WAL/recovery bits.

The actual implementation of relational algebra and a SQL language + parsing are little icing layers on top of a transactional storage engine.

cryptonectorβ€’about 4 hours ago
This. But TFA was specifically concerned with the relational algebra, so I'm giving it a pass :)
tenwz1β€’about 18 hours ago
Long before AI psychosis, there was FP psychosis, clinically defined as the intense psychological response to understanding functional programming concepts like recursion, higher order functions, monads, or in this case, continuation passing style.
remywangβ€’about 18 hours ago
CPS was also the OG "AI psychosis" when it appeared in Sussman and Steele's AI Memo #349: https://en.wikisource.org/wiki/Scheme:_An_Interpreter_for_Ex...
antonvsβ€’about 12 hours ago
Worth noting that’s a quote from the article (footnote 1).
epolanskiβ€’about 16 hours ago
At least FP psychosis leaves you more educated and with more tools in your box.

Not sure what the AI one gives you at a personal level.

icedchaiβ€’about 11 hours ago
A lobotomy? I've witnessed several individuals who were entirely dependent on Claude for any technical issue.
antonvsβ€’about 12 hours ago
As a happy sufferer from FP psychosis, I can tell you that LLMs can be a fantastic tool for learning if you choose to use them that way.
epolanskiβ€’about 7 hours ago
You're not describing AI psychosis tho.
unrealhoangβ€’about 18 hours ago
fredrikholmβ€’about 16 hours ago
Continuations predate transducers by some ~40 years and are mostly used as a means of control flow, but yes they are very similar.

Transducers are specialized to data transformation pipelines, continuations are a form of control flow from which you can derive a lot of cool things (exceptions, time travel debugging etc).

snthpyβ€’about 7 hours ago
Thank you! This is the concept I've been looking for. I always had the sense that compositional data transformation frameworks like PRQL or LINQ should have a clean categorical interpretation. I was exploring how this could be expressed in terms of monads but they usually start with the data while I was trying to formalise the composition of the transformations. I think transducers are it.

Transducers are just the morphisms in the category of the reducing-functions. No problem!

masfuerteβ€’about 11 hours ago
There was a similar article about the same database a few days ago:

https://news.ycombinator.com/item?id=48356563

DevelopingElkβ€’about 18 hours ago
CPS is a way of embedding imperative computation into an FP language. I think they built a mini compiler for their binary relation language, which is then Jitted by Julia.
IsTomβ€’about 12 hours ago
I'd rather compare CPS to goto than regular imperative computation.
cryptonectorβ€’about 8 hours ago
The continuations in CPS are closures. Goto basically isn't. GCC's computed goto is, but generally when people say 'goto' they mean the traditional C goto, which involves no closures. The goto analogy is not great for this reason.

A better analogy is that continuations are reified function call return addresses, since return addresses come with a frame pointer (explicit or implicit), and therefore are closure-like.

antonvsβ€’about 3 hours ago
A function call that's not artificially restricted to return to its caller is equivalent to a goto. See "Lambda: The Ultimate GOTO" by Guy Steele.

A continuation is a value that's passed to a function to tell it where to send its result when it's complete.

In imperative programming languages which invariably have restricted function calls, the continuation that every function receives is the address following the function call. This was just a mistake which the earliest programming languages committed, which has been perpetuated ever since, except in functional languages.