Sat, 13 Apr 2019 16:18:23 +0100 the property
Chengsong [Sat, 13 Apr 2019 16:18:23 +0100] rev 14
the property retrieve ar v = retrieve (bsimp ar) (decode erase(bsimp(ar)) code(v)) if |- v : r does not hold
Fri, 12 Apr 2019 19:26:13 +0100 test of
Chengsong [Fri, 12 Apr 2019 19:26:13 +0100] rev 13
test of retrieve r v = retrieve (bsimp r) (decode bsimp r code v)
Wed, 10 Apr 2019 17:06:24 +0100 removed C(c) The retrieve and code in the previous version is still not correct and will crash. no prob now.
Chengsong [Wed, 10 Apr 2019 17:06:24 +0100] rev 12
removed C(c) The retrieve and code in the previous version is still not correct and will crash. no prob now.
Wed, 10 Apr 2019 16:34:34 +0100 The C(Char) construct is incompatible with the code and retrieve in Fahad's thesis.
Chengsong [Wed, 10 Apr 2019 16:34:34 +0100] rev 11
The C(Char) construct is incompatible with the code and retrieve in Fahad's thesis. This causes the exception. Two ways of fixing this: delete C(C) construct (easy way around) or amend retrieve code etc. since the C(C) construct is intended for decoding Pred, and we don't use pred now, we shall delete this. This is the last veersion that contains C(CHAR)
Sat, 23 Mar 2019 11:53:09 +0000 exp and proof
Chengsong [Sat, 23 Mar 2019 11:53:09 +0000] rev 10
exp and proof
Fri, 22 Mar 2019 12:53:56 +0000 augmented version of proof sketch
Chengsong [Fri, 22 Mar 2019 12:53:56 +0000] rev 9
augmented version of proof sketch
Thu, 21 Mar 2019 13:26:07 +0000 pf
Chengsong [Thu, 21 Mar 2019 13:26:07 +0000] rev 8
pf
Sat, 16 Mar 2019 20:05:13 +0000 found the difference: caused by flats
Chengsong [Sat, 16 Mar 2019 20:05:13 +0000] rev 7
found the difference: caused by flats in ders_simp, the alts is at top most level , so no fuse and bits stay at the alts level whereas in ders + singele simp, the alts that should be the final top-level alts is not at the topmost level initially before simplification so it is opened up and bits fused. later it finds out itself the top level only aalts remaining, but the fuse is not reversible we do not know what happened either.
Sat, 16 Mar 2019 15:00:43 +0000 random test failed
Chengsong [Sat, 16 Mar 2019 15:00:43 +0000] rev 6
random test failed on the new simplification function. ("super_blexing_simp")
Sat, 16 Mar 2019 14:14:42 +0000 correctness test with enumeration
Chengsong [Sat, 16 Mar 2019 14:14:42 +0000] rev 5
correctness test with enumeration
Fri, 15 Mar 2019 12:27:12 +0000 :test whether bsimp(bders(r, s)) == ders_simp(r,s)
Chengsong [Fri, 15 Mar 2019 12:27:12 +0000] rev 4
:test whether bsimp(bders(r, s)) == ders_simp(r,s) This does not hold. As illustrated by the output of the example where string is abaa and regex is (a* + ab)* this property still holds when s = aba but after the derivative of the last character a, the result is negative. However this seems easily fixable as the difference is relatively small, it might be possible to find where the difference happens and by taking that difference into accound we have some function f s.t. f(bsimp(r,s)) = ders_simp(r,s) and mkeps(f(r)) = mkeps(r) This will complete the correctness proof. Even if finding such f is hard, it would still provide insights for the real difference between simp(der(simp(der(simp(der...... and simp(ders
Fri, 15 Mar 2019 10:46:46 +0000 removing PRED
Chengsong [Fri, 15 Mar 2019 10:46:46 +0000] rev 3
removing PRED why should it still be there after so many rounds of experiments? It should have been removed long ago since its existence will always make the compiler report errors. mysterious.:
Wed, 13 Mar 2019 15:27:09 +0000 more comments
Chengsong [Wed, 13 Mar 2019 15:27:09 +0000] rev 2
more comments
Wed, 13 Mar 2019 13:33:54 +0000 i
Chengsong [Wed, 13 Mar 2019 13:33:54 +0000] rev 1
i
Wed, 13 Mar 2019 13:14:38 +0000 run
Chengsong [Wed, 13 Mar 2019 13:14:38 +0000] rev 0
run scalac lex_blex_Frankensteined.scala BRexp.scala Element.scala Partial.scala Spiral.scala then run scala Spiral to see the results
(0) +48 +100 tip