2025/01/28

Newest at the top

2025-01-28 23:16:55 +0100 <tomsmeding> (that's a fun phrase out of context)
2025-01-28 23:16:50 +0100peterbecich(~Thunderbi@syn-047-229-123-186.res.spectrum.com) (Ping timeout: 244 seconds)
2025-01-28 23:16:30 +0100 <tomsmeding> I'd say the plagiarism is not the part that's most useless about my construction
2025-01-28 23:16:09 +0100confused_rust_en(~confused_@2603:7081:1600:6425:187f:fcc6:e582:3131) (Quit: Client closed)
2025-01-28 23:15:46 +0100Tuplanolla(~Tuplanoll@91-159-69-59.elisa-laajakaista.fi) Tuplanolla
2025-01-28 23:15:36 +0100 <monochrom> OK right but my point stands with errata on wording. Someone else has coded up f, so you just plagiarize that in the cata stage.
2025-01-28 23:15:24 +0100 <tomsmeding> s/do/to/
2025-01-28 23:15:17 +0100 <tomsmeding> your non-constructive proof is probably about a more subtle statement where T is forced do actually be something useful somehow
2025-01-28 23:14:25 +0100 <tomsmeding> which is extremely unhelpful
2025-01-28 23:14:18 +0100 <tomsmeding> given `f :: A -> B`, do `cata f . ana id`
2025-01-28 23:13:55 +0100 <monochrom> Oh wait, yeah, I misread, sorry!
2025-01-28 23:13:44 +0100 <tomsmeding> monochrom: `data T = MkT A`, happy now? :p
2025-01-28 23:13:29 +0100 <tomsmeding> if I read the venerable wikipedia correctly, the ana of my T would just be `ana :: (x -> A) -> x -> T` and the cata would be `cata :: (A -> r) -> T -> r`
2025-01-28 23:13:23 +0100 <monochrom> OTOH I am not sure how to kind-check "T = T A" :)
2025-01-28 23:12:49 +0100 <monochrom> I don't know. Too lazy to check. :)
2025-01-28 23:12:44 +0100takuan(~takuan@d8D86B601.access.telenet.be) (Remote host closed the connection)
2025-01-28 23:12:37 +0100 <tomsmeding> doesn't my T work?
2025-01-28 23:12:34 +0100merijn(~merijn@host-vr.cgnat-g.v4.dfn.nl) (Ping timeout: 260 seconds)
2025-01-28 23:12:28 +0100 <monochrom> Hence completely unhelpful even though sounding very elegant and unifying.
2025-01-28 23:12:00 +0100 <monochrom> So the theorem doesn't tell you how to design T. Instead, you have to design T and then the theorem just plagiarizes you!
2025-01-28 23:11:59 +0100jespada(~jespada@r190-133-42-215.dialup.adsl.anteldata.net.uy) (Ping timeout: 260 seconds)
2025-01-28 23:11:40 +0100Lord_of_Life(~Lord@user/lord-of-life/x-2819915) Lord_of_Life
2025-01-28 23:11:28 +0100 <monochrom> IIRC it's even worse. The only known proof is non-constructive, or only relatively constructive. It goes: since we are told it's computable, someone must have found an algorithm, now just turn that into T.
2025-01-28 23:11:18 +0100Lord_of_Life(~Lord@user/lord-of-life/x-2819915) (Quit: Laa shay'a waqi'un moutlaq bale kouloun moumkine)
2025-01-28 23:09:46 +0100 <tomsmeding> ah, that's wrong. Set `data T = T A`.
2025-01-28 23:09:25 +0100 <tomsmeding> if the function goes A -> B, set T = A.
2025-01-28 23:08:58 +0100 <monochrom> Related unhelpful theorem: For every computable function, there exists an intermediate data structure T such that the function is composed of ana'ing input into T and then cata'ing T into output.
2025-01-28 23:08:43 +0100img(~img@user/img) (Ping timeout: 245 seconds)
2025-01-28 23:07:24 +0100merijn(~merijn@host-vr.cgnat-g.v4.dfn.nl) merijn
2025-01-28 23:07:19 +0100 <tomsmeding> agreed
2025-01-28 23:07:19 +0100confused_rust_en(~confused_@2603:7081:1600:6425:187f:fcc6:e582:3131)
2025-01-28 23:07:02 +0100 <int-e> The serious part though is that when figuring out algorithms on simple data structures... "what recursion scheme is this" doesn't seem like a helpful question.
2025-01-28 23:06:51 +0100 <haskellbridge> <alexfmpe> Might need some unsafe functions in there for traverse-ish if you only require Foldable
2025-01-28 23:06:18 +0100 <int-e> It does get interesting when you compose these things... one early showcase is build/foldr fusion.
2025-01-28 23:06:09 +0100img_(~img@user/img) img
2025-01-28 23:05:49 +0100 <haskellbridge> <alexfmpe> You can write all the other ones via it
2025-01-28 23:05:35 +0100 <haskellbridge> <alexfmpe> Fold *is* recursion
2025-01-28 23:05:33 +0100 <tomsmeding> I guess foldMap is a little less powerful than a full catamorphism would be
2025-01-28 23:05:06 +0100 <monochrom> I consider foldMap to be under monoidology not recursion schemes. >:)
2025-01-28 23:04:55 +0100 <mauke> map is quite useful
2025-01-28 23:04:36 +0100 <tomsmeding> int-e: foldMap is quite useful.
2025-01-28 23:03:13 +0100machinedgod(~machinedg@d108-173-18-100.abhsia.telus.net) machinedgod
2025-01-28 23:02:07 +0100 <int-e> Recursion schemes are silly; explicit recursion is underrated. Change my mind.
2025-01-28 23:00:50 +0100 <monochrom> Ah, I need to respect that. But only out of a mathematical/logical reason: In type theory with user-definable algebraic types (e.g. Agda, Lean), the auto-gen'ed induction principle is a para.
2025-01-28 22:59:43 +0100 <EvanR_> the effect of code on humans and vice versa
2025-01-28 22:59:01 +0100 <EvanR_> monochrom, stuff like recursion schemes might fall under programming geography
2025-01-28 22:57:31 +0100sawilagar(~sawilagar@user/sawilagar) (Ping timeout: 252 seconds)
2025-01-28 22:57:02 +0100Midjak(~MarciZ@82.66.147.146) (Quit: This computer has gone to sleep)
2025-01-28 22:56:39 +0100merijn(~merijn@host-vr.cgnat-g.v4.dfn.nl) (Ping timeout: 260 seconds)
2025-01-28 22:55:44 +0100tnt2tnt1