Commit Graph

859 Commits

Author SHA1 Message Date
Nathan Braswell
96ea2fad8d Port over most of the rest, some left commented out. Need to figure out how we actually want to handle prim_combs putting themselves in the output. This comes up a lot with give_up_eval_params. Also, '() = nil counts as true for if in Scheme, need to figure that out :/ 2021-11-23 01:54:20 -05:00
Nathan Braswell
7c32c3811a Fix indexing bug, first partial eval! 2021-11-22 01:46:59 -05:00
Nathan Braswell
d26fcee9b6 Port more, start fixing bugs. Something weird with slice/drop/take 2021-11-22 01:28:05 -05:00
Nathan Braswell
b3261f3db0 Bunch more ported, including all of the actual partial_eval function 2021-11-20 01:13:22 -05:00
Nathan Braswell
551e60cfe1 Destructuring lambda, fix for compiling 2021-11-19 01:08:27 -05:00
Nathan Braswell
d4ff61ade5 Some work from previously, and also now an implementation of destructuring let 2021-11-16 00:15:53 -05:00
Nathan Braswell
627ccb4aa0 Begin port of partial_eval to Chicken Scheme, with a bunch of stuff to define a vaguely kraken-like environment in scheme 2021-11-09 00:35:58 -05:00
Nathan Braswell
437c2c7166 Some bugfixes, a small recursive test (that currently loops forever), and the sierpinski triangle from a while back I forgot to commit 2021-11-07 00:47:44 -04:00
Nathan Braswell
c0a07b54ce Fixed up! 2021-10-19 02:45:56 -04:00
Nathan Braswell
e0c4366771 With some bugfixes, sucessfully got let4.7 working, which is like let5 but written in macro style! Stiil need to finish up strip for the cases like let5 that we can't finish for now. 2021-10-19 02:26:19 -04:00
Nathan Braswell
92ac879c6d Finally fixed let_test4. Let_test5 will require more thinking to see if it's even possible, and what macro like means etc 2021-10-18 00:46:39 -04:00
Nathan Braswell
923c4565fb prep for useing de bruijn 2021-10-17 17:39:38 -04:00
Nathan Braswell
e322fc7cd7 Finally correct again, but with the latest safety fixes no longer even evaluates the easier lets. The issue is that we're not executing combiners that use de if we don't have a real de (normally the enclosing function's se) because that's subject to the alpha-renaming problem. de is essentially a parameter, which is subtle and easy to miss when looking at the safety conditions, and indeed I did miss it earlier 2021-10-15 23:10:58 -04:00
Nathan Braswell
64c793d9f4 Flesh out the closes over test. Still doesnt' partial eval like we want, need to investigate why - have idea for specalizing function but do have to be careful with actual_function 2021-09-14 02:01:31 -04:00
Nathan Braswell
ec9083a958 Fixed bug with y, but still not partially evaluating the lets with later :/ 2021-09-12 01:37:07 -04:00
Nathan Braswell
f89b21420a Ok, figured out why let5 is failing and wrote down a plan of attack 2021-09-07 00:06:19 -04:00
Nathan Braswell
12271ff27c Bug fixed and back to state before refactor/rewrite. Need to get that darn let5 working now! That's why we did this 2021-09-06 23:00:04 -04:00
Nathan Braswell
873e7c4244 Working through the bugs, got the first few working 2021-09-06 12:29:05 -04:00
Nathan Braswell
6a47375d28 Ok, refactored the whole thing! It's now always operating on marked values with a mark step at the beginning, which should solve our stripping problems. It parses, but crashes, but it's 3am, so I'm saving and going to bed 2021-09-06 03:00:33 -04:00
Nathan Braswell
49d5a196aa 2 steps forward, 1 step back - I have arrays (and I think varargs) working, but let5_test is now not partial evaling as far as it should because of my fix. Detailed explanation in the comments, but it looks like we are going to have to insert that eval_strip hack, or somesuch 2021-09-05 00:25:33 -04:00
Nathan Braswell
b44ff104fb Implement variadic paremters, found additional bug for array, still need to handle recursion too 2021-08-26 01:03:36 -04:00
Nathan Braswell
26e9c5a41f Fix a bug in eval strip not actually stripping in the proper eval way - f there's a later anywhere in there, it has to desist, which is now implemented. Added do tests - we have to add support for & params, which I had forgotten, and I belive it now loops infinately because it tries to partially evaluate a recursive function! 2021-08-25 01:32:24 -04:00
Nathan Braswell
649e0107d4 And lambda is working nicely too, once I added support for val to the function call evaluaator (just looking it up in comb_to_mark_map) 2021-08-24 00:33:29 -04:00
Nathan Braswell
634812cea4 Got it working! 2021-08-23 23:43:47 -04:00
Nathan Braswell
2cd85a552d Some more tests and cleanup, looks like we're going to have to do either a try-eval thing or CPS-style partial evaluator, which I'm reading up on 2021-08-22 20:27:48 -04:00
Nathan Braswell
7700f0b709 FIXED THE BUG! 2021-08-22 13:03:33 -04:00
Nathan Braswell
c9e2e4659b Completely untested, but added partial eval for all array methods and and/or - this is pretty much everything! We don't bother with meta or error/recover right now though 2021-08-17 23:09:42 -04:00
Nathan Braswell
04f1c76bd7 Factored out parameter eval for some combinators and then added combiner? and env? 2021-08-17 20:31:07 -04:00
Nathan Braswell
47d5149400 Implement smart cond partial-eval 2021-08-17 18:17:42 -04:00
Nathan Braswell
772b984de0 Ok, more bugfixes & comments, and got eval working! 2021-08-17 01:19:38 -04:00
Nathan Braswell
e8747ef899 Bugfix and improvment, eval one works even though eval isn't implemented yet! 2021-08-16 11:54:05 -04:00
Nathan Braswell
62a238e041 Added wrap/unwrap and a vau test that uses wrap! 2021-08-16 01:20:10 -04:00
Nathan Braswell
550565a235 More vau usage working 2021-08-16 00:37:56 -04:00
Nathan Braswell
05092cba76 First vau-involved partial evals working! 2021-08-15 01:27:53 -04:00
Nathan Braswell
b3c02c82b3 Create and pass through comb_to_mark_map to allow us to re-mark stripped expressions so we can evaluate them mutliple times, etc, etc 2021-08-11 23:30:49 -04:00
Nathan Braswell
f09962ddc4 Add 2 parameter vau that discards dynamic env 2021-08-10 23:26:22 -04:00
Nathan Braswell
95b37da44e Ok, I think this is a correct? skeleton, implemented as much as I did yesterday 2021-08-10 22:56:12 -04:00
Nathan Braswell
e1fa65deaf Starting work on a partial evaluator - just sketching for now, needs a bunch of work and likely some foundational changes 2021-08-10 00:23:14 -04:00
Nathan Braswell
d2215c2831 Fix some of the massive speed drop from destructuring lambda by checking to see if it actually needs to destrucure first. Still slower than it was, but not 10x anymore. Maybe 1.5-2x? 2021-08-05 01:11:14 -04:00
Nathan Braswell
ae82af6636 Bugfix & added an extra lambda wrapping around term/nterm so that their value can be made recursive with let-rec, and with that the parser works! On the other hand, it takes 38 seconds to parse 'a,a,a' with the grammer A='a'|'a' ',' A .... so that could be a lot better. 2021-08-05 00:39:56 -04:00
Nathan Braswell
c8c876e1bc Gonna checkpoint here - got basic fungll working, did a mod to allow strings as terminals, working on getting recursion working. 2021-08-05 00:07:44 -04:00
Nathan Braswell
5a61d5f90c Added destructuring lambda/rec-lambda, changed let to use the same [] array destructuring syntax, added basic multiset & set-foldl. Fixed a bunch of bugs in fungll, hopefully close to working, but just realized that < is only defined for ints, while it's how the RB-Tree set/map sort their values/keys, so I'll need to extend it like = for all types. Tomorrow! 2021-08-04 00:56:04 -04:00
Nathan Braswell
d38cd3e61e Put in title of paper / authors / url 2021-08-03 01:10:10 -04:00
Nathan Braswell
c96f20c80e Add lcompose to prelude, size to rb, and sketch out fungll. Still haven't figured out the exact datatype for grammer_slots and have decided to implement [] destrucuring in lambda params, and change let destructuring to use []. 2021-08-03 00:56:07 -04:00
Nathan Braswell
dc712060cd generalize RB-Tree and make wrapper functions to use as a set or map 2021-08-02 20:34:01 -04:00
Nathan Braswell
e0802baf5e Extend match to support ~unquote for matching against the *value* of expressions or variables, and use that to implement deletion for the RB-tree set 2021-08-01 23:48:41 -04:00
Nathan Braswell
93fd0d1943 Initial insert-only RB tree implementing a set 2021-08-01 22:15:58 -04:00
Nathan Braswell
537386d97b Extended foldl and foldr to be variadic, fixed foldr, and added pattern matching! 2021-08-01 20:21:14 -04:00
Nathan Braswell
dfde35ee79 Add in basic element section 2021-08-01 00:23:41 -04:00
Nathan Braswell
ee4a664660 Add global and table sections 2021-07-29 00:56:57 -04:00