From 4f293ab1eb6d51279e1ce6c6540cd9125130f876 Mon Sep 17 00:00:00 2001 From: ncik-roberts Date: Fri, 29 Jul 2016 01:06:15 -0400 Subject: [PATCH] Adds all files --- .cm/GUID/arithmetic.sml | 1 + .cm/GUID/directions.sml | 1 + .cm/GUID/examples.sml | 1 + .cm/GUID/simulator.sml | 1 + .cm/GUID/turing.sig | 1 + .cm/GUID/turing.sml | 1 + .cm/SKEL/arithmetic.sml | 2 + .cm/SKEL/directions.sml | 2 + .cm/SKEL/examples.sml | 2 + .cm/SKEL/simulator.sml | 2 + .cm/SKEL/turing.sig | 2 + .cm/SKEL/turing.sml | 2 + .cm/x86-unix/arithmetic.sml | Bin 0 -> 10672 bytes .cm/x86-unix/directions.sml | Bin 0 -> 574 bytes .cm/x86-unix/examples.sml | Bin 0 -> 14896 bytes .cm/x86-unix/simulator.sml | Bin 0 -> 2536 bytes .cm/x86-unix/turing.sig | Bin 0 -> 914 bytes .cm/x86-unix/turing.sml | Bin 0 -> 3422 bytes examples.sml | 67 ++++++++++++++++++ sources.cm | 4 ++ turingMachine/.cm/GUID/directions.sml | 1 + turingMachine/.cm/GUID/turing.sig | 1 + turingMachine/.cm/GUID/turing.sml | 1 + turingMachine/.cm/SKEL/directions.sml | 2 + turingMachine/.cm/SKEL/turing.sig | 2 + turingMachine/.cm/SKEL/turing.sml | 2 + turingMachine/.cm/x86-unix/directions.sml | Bin 0 -> 617 bytes turingMachine/.cm/x86-unix/turing.sig | Bin 0 -> 1052 bytes turingMachine/.cm/x86-unix/turing.sml | Bin 0 -> 3575 bytes turingMachine/directions.sml | 9 +++ turingMachine/sources.cm | 7 ++ .../stateMachine/.cm/GUID/functionsm.sml | 1 + .../stateMachine/.cm/GUID/stateMachine.sig | 1 + .../stateMachine/.cm/SKEL/functionsm.sml | 2 + .../stateMachine/.cm/SKEL/stateMachine.sig | 2 + .../stateMachine/.cm/x86-unix/functionsm.sml | Bin 0 -> 2452 bytes .../.cm/x86-unix/stateMachine.sig | Bin 0 -> 821 bytes turingMachine/stateMachine/functionsm.sml | 32 +++++++++ turingMachine/stateMachine/sources.cm | 4 ++ turingMachine/stateMachine/stateMachine.sig | 22 ++++++ .../tape/.cm/GUID/biinfinitetape.sml | 1 + turingMachine/tape/.cm/GUID/infinitetape.sml | 1 + turingMachine/tape/.cm/GUID/tape.sig | 1 + .../tape/.cm/SKEL/biinfinitetape.sml | 2 + turingMachine/tape/.cm/SKEL/infinitetape.sml | 2 + turingMachine/tape/.cm/SKEL/tape.sig | 2 + .../tape/.cm/x86-unix/biinfinitetape.sml | Bin 0 -> 2664 bytes .../tape/.cm/x86-unix/infinitetape.sml | Bin 0 -> 2632 bytes turingMachine/tape/.cm/x86-unix/tape.sig | Bin 0 -> 566 bytes turingMachine/tape/biinfinitetape.sml | 31 ++++++++ turingMachine/tape/infinitetape.sml | 32 +++++++++ turingMachine/tape/sources.cm | 5 ++ turingMachine/tape/tape.sig | 15 ++++ turingMachine/turing.sig | 13 ++++ turingMachine/turing.sml | 27 +++++++ 55 files changed, 310 insertions(+) create mode 100644 .cm/GUID/arithmetic.sml create mode 100644 .cm/GUID/directions.sml create mode 100644 .cm/GUID/examples.sml create mode 100644 .cm/GUID/simulator.sml create mode 100644 .cm/GUID/turing.sig create mode 100644 .cm/GUID/turing.sml create mode 100644 .cm/SKEL/arithmetic.sml create mode 100644 .cm/SKEL/directions.sml create mode 100644 .cm/SKEL/examples.sml create mode 100644 .cm/SKEL/simulator.sml create mode 100644 .cm/SKEL/turing.sig create mode 100644 .cm/SKEL/turing.sml create mode 100644 .cm/x86-unix/arithmetic.sml create mode 100644 .cm/x86-unix/directions.sml create mode 100644 .cm/x86-unix/examples.sml create mode 100644 .cm/x86-unix/simulator.sml create mode 100644 .cm/x86-unix/turing.sig create mode 100644 .cm/x86-unix/turing.sml create mode 100644 examples.sml create mode 100644 sources.cm create mode 100644 turingMachine/.cm/GUID/directions.sml create mode 100644 turingMachine/.cm/GUID/turing.sig create mode 100644 turingMachine/.cm/GUID/turing.sml create mode 100644 turingMachine/.cm/SKEL/directions.sml create mode 100644 turingMachine/.cm/SKEL/turing.sig create mode 100644 turingMachine/.cm/SKEL/turing.sml create mode 100644 turingMachine/.cm/x86-unix/directions.sml create mode 100644 turingMachine/.cm/x86-unix/turing.sig create mode 100644 turingMachine/.cm/x86-unix/turing.sml create mode 100644 turingMachine/directions.sml create mode 100644 turingMachine/sources.cm create mode 100644 turingMachine/stateMachine/.cm/GUID/functionsm.sml create mode 100644 turingMachine/stateMachine/.cm/GUID/stateMachine.sig create mode 100644 turingMachine/stateMachine/.cm/SKEL/functionsm.sml create mode 100644 turingMachine/stateMachine/.cm/SKEL/stateMachine.sig create mode 100644 turingMachine/stateMachine/.cm/x86-unix/functionsm.sml create mode 100644 turingMachine/stateMachine/.cm/x86-unix/stateMachine.sig create mode 100644 turingMachine/stateMachine/functionsm.sml create mode 100644 turingMachine/stateMachine/sources.cm create mode 100644 turingMachine/stateMachine/stateMachine.sig create mode 100644 turingMachine/tape/.cm/GUID/biinfinitetape.sml create mode 100644 turingMachine/tape/.cm/GUID/infinitetape.sml create mode 100644 turingMachine/tape/.cm/GUID/tape.sig create mode 100644 turingMachine/tape/.cm/SKEL/biinfinitetape.sml create mode 100644 turingMachine/tape/.cm/SKEL/infinitetape.sml create mode 100644 turingMachine/tape/.cm/SKEL/tape.sig create mode 100644 turingMachine/tape/.cm/x86-unix/biinfinitetape.sml create mode 100644 turingMachine/tape/.cm/x86-unix/infinitetape.sml create mode 100644 turingMachine/tape/.cm/x86-unix/tape.sig create mode 100644 turingMachine/tape/biinfinitetape.sml create mode 100644 turingMachine/tape/infinitetape.sml create mode 100644 turingMachine/tape/sources.cm create mode 100644 turingMachine/tape/tape.sig create mode 100644 turingMachine/turing.sig create mode 100644 turingMachine/turing.sml diff --git a/.cm/GUID/arithmetic.sml b/.cm/GUID/arithmetic.sml new file mode 100644 index 0000000..d48465e --- /dev/null +++ b/.cm/GUID/arithmetic.sml @@ -0,0 +1 @@ +guid-(sources.cm):arithmetic.sml-1468810562.778 diff --git a/.cm/GUID/directions.sml b/.cm/GUID/directions.sml new file mode 100644 index 0000000..0f72d86 --- /dev/null +++ b/.cm/GUID/directions.sml @@ -0,0 +1 @@ +guid-(sources.cm):directions.sml-1469755981.939 diff --git a/.cm/GUID/examples.sml b/.cm/GUID/examples.sml new file mode 100644 index 0000000..2f468f5 --- /dev/null +++ b/.cm/GUID/examples.sml @@ -0,0 +1 @@ +guid-(sources.cm):examples.sml-1469756132.181 diff --git a/.cm/GUID/simulator.sml b/.cm/GUID/simulator.sml new file mode 100644 index 0000000..345edf8 --- /dev/null +++ b/.cm/GUID/simulator.sml @@ -0,0 +1 @@ +guid-(sources.cm):simulator.sml-1468810230.284 diff --git a/.cm/GUID/turing.sig b/.cm/GUID/turing.sig new file mode 100644 index 0000000..ef32057 --- /dev/null +++ b/.cm/GUID/turing.sig @@ -0,0 +1 @@ +guid-(sources.cm):turing.sig-1468948300.066 diff --git a/.cm/GUID/turing.sml b/.cm/GUID/turing.sml new file mode 100644 index 0000000..d721cb9 --- /dev/null +++ b/.cm/GUID/turing.sml @@ -0,0 +1 @@ +guid-(sources.cm):turing.sml-1468813412.821 diff --git a/.cm/SKEL/arithmetic.sml b/.cm/SKEL/arithmetic.sml new file mode 100644 index 0000000..04cf672 --- /dev/null +++ b/.cm/SKEL/arithmetic.sml @@ -0,0 +1,2 @@ +Skeleton 5 +d2fLRS"ad"TestArithmetic"h4aArithmeticTM"jh2ad"T"jh1gp1e"BiinfiniteTape"aSM"jh0gp1e"FunctionSM"gp1e"Turing"egp29f1 \ No newline at end of file diff --git a/.cm/SKEL/directions.sml b/.cm/SKEL/directions.sml new file mode 100644 index 0000000..b70b1f0 --- /dev/null +++ b/.cm/SKEL/directions.sml @@ -0,0 +1,2 @@ +Skeleton 5 +d2ad"LRS"0ad"LR" \ No newline at end of file diff --git a/.cm/SKEL/examples.sml b/.cm/SKEL/examples.sml new file mode 100644 index 0000000..11bafcf --- /dev/null +++ b/.cm/SKEL/examples.sml @@ -0,0 +1,2 @@ +Skeleton 5 +d3fLRS"aTM_Creator"h3aTM"jh2ad"T"jh1gp1e"BiinfiniteTape"aSM"jh0gp1e"FunctionSM"gp1e"Turing"egp2+ad"TM_Tester"h2egp1 f1 \ No newline at end of file diff --git a/.cm/SKEL/simulator.sml b/.cm/SKEL/simulator.sml new file mode 100644 index 0000000..c44a876 --- /dev/null +++ b/.cm/SKEL/simulator.sml @@ -0,0 +1,2 @@ +Skeleton 5 +ae"Simulator"i3aT"gp1c"TAPE"aSM"gp1c"STATE_MACHINE"f2h0 \ No newline at end of file diff --git a/.cm/SKEL/turing.sig b/.cm/SKEL/turing.sig new file mode 100644 index 0000000..c814501 --- /dev/null +++ b/.cm/SKEL/turing.sig @@ -0,0 +1,2 @@ +Skeleton 5 +ac"TURING_MACHINE"h2ad"T"gp1c"TAPE"ad"SM"gp1c"STATE_MACHINE" \ No newline at end of file diff --git a/.cm/SKEL/turing.sml b/.cm/SKEL/turing.sml new file mode 100644 index 0000000..77340d3 --- /dev/null +++ b/.cm/SKEL/turing.sml @@ -0,0 +1,2 @@ +Skeleton 5 +ae"Turing"i2aT"gp1c"TAPE"aSM"gp1c"STATE_MACHINE"jh2a gp1 agp1gp1c"TURING_MACHINE" \ No newline at end of file diff --git a/.cm/x86-unix/arithmetic.sml b/.cm/x86-unix/arithmetic.sml new file mode 100644 index 0000000000000000000000000000000000000000..ea64e98ef782adc857a06757cc5ebff91cad805e GIT binary patch literal 10672 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 NmVlXXg(gEN;RkD|zk~n) literal 0 HcmV?d00001 diff --git a/.cm/x86-unix/examples.sml b/.cm/x86-unix/examples.sml new file mode 100644 index 0000000000000000000000000000000000000000..a72be611cca9f93a7eb4dc229bcc33f7e9b4ccc8 GIT binary patch literal 14896 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 literal 0 HcmV?d00001 diff --git a/examples.sml b/examples.sml new file mode 100644 index 0000000..4123e4d --- /dev/null +++ b/examples.sml @@ -0,0 +1,67 @@ +structure TM_Creator = +struct + datatype action = Accept | Reject + + structure TM = Turing( + structure T = BiinfiniteTape(open LRS) + structure SM = FunctionSM( + type direction = LRS.direction + type action = action)) + + (* Have access to SM constructor and subroutine without an annoying prefix *) + open TM.SM + (* Have access to Left/Right/Stay without an annoying prefix *) + open LRS + + datatype symbol = One | Zero + + (* Moves the tape to the right one starting from current position *) + (* Halts with head on rightmost nonblank *) + fun qRightZero NONE = (SOME Zero, Stay, Halt Accept) + | qRightZero (SOME One) = (SOME Zero, Right, SM qRightOne) + | qRightZero (SOME Zero) = (SOME Zero, Right, SM qRightZero) + and qRightOne NONE = (SOME One, Stay, Halt Accept) + | qRightOne (SOME One) = (SOME One, Right, SM qRightOne) + | qRightOne (SOME Zero) = (SOME One, Right, SM qRightZero) + + (* Moves the tape to the left one starting from current position *) + (* Halts with head on leftmost nonblank *) + fun qLeftZero NONE = (SOME Zero, Stay, Halt Accept) + | qLeftZero (SOME One) = (SOME Zero, Left, SM qLeftOne) + | qLeftZero (SOME Zero) = (SOME Zero, Left, SM qLeftZero) + and qLeftOne NONE = (SOME One, Stay, Halt Accept) + | qLeftOne (SOME One) = (SOME One, Left, SM qLeftOne) + | qLeftOne (SOME Zero) = (SOME One, Left, SM qLeftZero) + + (* Let's separate every pair of ones *) + fun qStart NONE = (NONE, Left, Halt Accept) + | qStart (SOME Zero) = (SOME Zero, Right, SM qStart) + | qStart (SOME One) = (SOME One, Right, SM qJustReadOne) + and qJustReadOne NONE = (NONE, Left, Halt Accept) + | qJustReadOne (SOME Zero) = (SOME Zero, Right, SM qStart) + | qJustReadOne (SOME One) = (SOME One, Left, SM (qDepair ())) + and qDepair () = + let + fun onHalt _ x = (x, Stay, SM qStart) + in + subroutine (SM qLeftZero) onHalt + end +end + +structure TM_Tester = +struct + open TM_Creator + + val (Accept, [SOME Zero]) = TM.simulate (SM qRightZero) [] + + val tape = [One, One] + val (Accept, [SOME Zero, SOME One, SOME One]) = TM.simulate (SM qRightZero) tape + val (Accept, [SOME One, SOME One, SOME One]) = TM.simulate (SM qLeftOne) tape + + (* Let's separate the ones in friends! *) + val depair = SM qStart + val friends = [One, One, Zero, Zero, One, One, One] + val result = [SOME One, SOME Zero, SOME One, SOME Zero, SOME Zero, SOME One, + SOME Zero, SOME One, SOME Zero, SOME One] + val true = (Accept, result) = TM.simulate depair friends +end diff --git a/sources.cm b/sources.cm new file mode 100644 index 0000000..ff16c15 --- /dev/null +++ b/sources.cm @@ -0,0 +1,4 @@ +Group is + $/basis.cm + turingMachine/sources.cm + examples.sml diff --git a/turingMachine/.cm/GUID/directions.sml b/turingMachine/.cm/GUID/directions.sml new file mode 100644 index 0000000..afda68e --- /dev/null +++ b/turingMachine/.cm/GUID/directions.sml @@ -0,0 +1 @@ +guid-(sources.cm):turingMachine/(sources.cm):directions.sml-1469756132.136 diff --git a/turingMachine/.cm/GUID/turing.sig b/turingMachine/.cm/GUID/turing.sig new file mode 100644 index 0000000..8f6872f --- /dev/null +++ b/turingMachine/.cm/GUID/turing.sig @@ -0,0 +1 @@ +guid-(sources.cm):turingMachine/(sources.cm):turing.sig-1469756132.118 diff --git a/turingMachine/.cm/GUID/turing.sml b/turingMachine/.cm/GUID/turing.sml new file mode 100644 index 0000000..dcb676c --- /dev/null +++ b/turingMachine/.cm/GUID/turing.sml @@ -0,0 +1 @@ +guid-(sources.cm):turingMachine/(sources.cm):turing.sml-1469756132.150 diff --git a/turingMachine/.cm/SKEL/directions.sml b/turingMachine/.cm/SKEL/directions.sml new file mode 100644 index 0000000..b70b1f0 --- /dev/null +++ b/turingMachine/.cm/SKEL/directions.sml @@ -0,0 +1,2 @@ +Skeleton 5 +d2ad"LRS"0ad"LR" \ No newline at end of file diff --git a/turingMachine/.cm/SKEL/turing.sig b/turingMachine/.cm/SKEL/turing.sig new file mode 100644 index 0000000..c814501 --- /dev/null +++ b/turingMachine/.cm/SKEL/turing.sig @@ -0,0 +1,2 @@ +Skeleton 5 +ac"TURING_MACHINE"h2ad"T"gp1c"TAPE"ad"SM"gp1c"STATE_MACHINE" \ No newline at end of file diff --git a/turingMachine/.cm/SKEL/turing.sml b/turingMachine/.cm/SKEL/turing.sml new file mode 100644 index 0000000..77340d3 --- /dev/null +++ b/turingMachine/.cm/SKEL/turing.sml @@ -0,0 +1,2 @@ +Skeleton 5 +ae"Turing"i2aT"gp1c"TAPE"aSM"gp1c"STATE_MACHINE"jh2a gp1 agp1gp1c"TURING_MACHINE" \ No newline at end of file diff --git a/turingMachine/.cm/x86-unix/directions.sml b/turingMachine/.cm/x86-unix/directions.sml new file mode 100644 index 0000000000000000000000000000000000000000..4757b3a55907671cb2706b5c5e13e197cb984955 GIT binary patch literal 617 zcmXpsG|)4*P*A9_FjD{mE(Qo-gwhUB+8av8FfcIMomwihb4il_KYibm6&HTienaO& z)xxMe7z0Y@&D%Rk;7?t`Z1YuZ+jy_ttV=J=OwrXS&Mz%WPA%3;&egOkDJ{y(OZQDo z&dAJ5)kl#^$t+4uF3HT#E7mK{&CxY9F|#x`H8V6e(lazRgE=2$lMjfnu2JDBmpRVP z1oY5xcNUPhj=OV!sNQ^*=HmkYpS@=IAEKi0KSjj@)lyV@fEqZA3Z5+T2~sk3adu?L zOG`5@c(}+XHLXO+H2J?^$-_ejnHU(781fPg|H~&iG8-m8S_C&j$>_;{!6OWLPaZA` z%1qBFQ98m143xCX3`_=@M*sEyGa3B1|KBK>mRIn35JnH2mNgt>|X=Bg&sBu7re zD+c`L09pjxU5aKK%0gp)d@1# z+I4g%@v4aQqIeM6gBRUkV?#uCQU;=zZX%mrL@$cU=lhzW?J$IVdHKEH@BQ9;VOh7U zuitK;>G#{=I)WOniT!Y7{|qB!`u%)s#d7rCyJx<&$tRZ|4z@N@ka93?k6pRCviV?V z%(3yJ@M@E}zkH|l*X+dIzQ={9En9DAzYiUL)7JL#$Jd`1K7D)t$T^jj6FuEpI-7}$ znk$| z&xphvc9L+6-fk2(BB}>@7FOLU#V%bOi;i521o_di=rH#3L8K9rE_u}tr5NTyO6W`J zU<()_WtD-1@d)PlpjnIK@mMf6{8vSi{OWc|i0g7%!K@IZA~2`ML1Bx8*2vsxhKJmQ zoDu8N;j`61O#o`Tpo@kM05$_K1E344IDRuVnN9-A2b-AcI#VHoYsAUyRmgmRbe6YK zS>G$eyTs69O;j#b)1u)a36b28S}lzVNgey*ByW=vWr-116(08tVXnH4fNTPVxehm| zmmwX3oR8$XLg=*#NeZu4$s7Xif>lb8{0T-N`IDRwW>_*mAj886xg_rnF=T;}6flrV zU#IQxA#l*l2*aM;5{q|B9G=D=>@lkJl3X|NgfIdHJC(7yL4@R-P=3L0%;508b1^}^ zFPe22HIKy^1-s9OqmqVH0W0E+9-#%j|IC3<6--u0;drfD;T$RWp&A4ET6Qv%&g$?h z9$*-4(cVbDi!2VpZHg*xH>0eYC{GvFdPZ#(MJt_Gh0ZHLyP@nFKzC%`s~9W9q?3Xh z;KxP^EgUI!kfOgPDyOnZy8L?c#SX&?-BD83bX-$jItDXGz_r4@WDfR40&amU1z3`6 RH!Ccsao}Oz21h3y<{yI5q4fX& literal 0 HcmV?d00001 diff --git a/turingMachine/.cm/x86-unix/turing.sml b/turingMachine/.cm/x86-unix/turing.sml new file mode 100644 index 0000000000000000000000000000000000000000..d7c2a81e3d10a0dce8a5e4408c9f22870b6419a2 GIT binary patch literal 3575 zcmai1eM}qY8NYKb;b`5}tyrNNO4!YE8XG z_iS^pRI|8`_ul9CeEgn|JG@>`M^A5C+sWSUHvI0BB*}q8#?g!;hl74$>(V$UNjs81 z{LL$_jhA2iUeC|;*B`j{{>$=lhYZwp-}(29ANQR3?zi8#^zkp}zqoyEsi>bb^*ie( z^Kk5iufKWq)xREczg^LPcU9hQ=8bD_Hr)UHzg+TP9{QDtHFn!VT?9%%&H}P%>QOspFMA7CqU;0K&WaL?DzF!UhG9?` z6SPnk1pmx3R%>N0Fj1rr3EBOq^8QzJD=G& z+D9D0^C-%INTC{fd&XGYVcpldnvO$rJ zq3n?ZmE{zwCIw|tD<%>Y@mzssqLRvKh?JXpmtA)oDxzKvYnDrtlZy%(Mxgw{CEzwb z-4f4;WDHl!==Sz_25R7S+$=7Nsj(ZJ#aIaRvnT7-f-J_U8j$L%LbO^l=k2!sUtc+G zeI=McU#WE}s(tk?)YtmzB<@Z9DZ7o&=_?h%3l^Rx?@WFD-!={cth3q|2UR018UoYj zIo!Bd#)&~iIT=+DpVe*EUVRZdsY@s&?;$;u?^o@5KgXBzHD7*2AXA^VV?tJsSGy{z zRvQ%lP|uSi)S&n1{JX*%t3aNGVpDIj>)qD-U8wB3YK+-?^}ZrvLS`f8+?7vkeBHD6 zPmxBD_rJaWN3>#XhAi0i92dP${Xi8pr6OpEvST9Xl9)=!K+$QGn%FUg?WO1uI*m+f zSsH}|6#a1*=4;7FkU_+6v-RNF3bl90g+!wQm5xZ~ zCmBX_SVbl+Ch8pg!(w1@lYzC1WR(`%T=+-HQYtH!FBT zyx=-aSCZm4#TjYZ`eA0R=vxee4c=T*i-`|6ttUK@2?gX#D&@=l?LtiR1v9}9FKqwr z(IIv|A2Ab}~Jiw29-fYVA6(nJ**?NlOnl8m)~T*eE1&$)n$z8P85*Hx$?@CkAC7 z_XqhNIql=~y}WtphO|^zTf%)xCSwYzn-RKbxicm4a!+pcLL@O=(EJm8!I7F=O38`k zOi0^zK=ZAxNK5>5A2ghP#Iw30FF_oOatANB2Bkkaq*Nx9Tjl!!JtL+^-jVV8@;=@R zCvj;eUza7+(Js`H7iH2vo6Hxd3r7pHU{qAp_WvwIMKwTMDxjvg(UhJT^bUH1{9MD# zaw8UI0w4}NN=iB>^pHA3V`qWdj3%?eVa>PfS23r%W^xGJ)6s(0N4HX RrS2aECB~j$+7pmG{{=}8DqR2o literal 0 HcmV?d00001 diff --git a/turingMachine/directions.sml b/turingMachine/directions.sml new file mode 100644 index 0000000..cb88f5d --- /dev/null +++ b/turingMachine/directions.sml @@ -0,0 +1,9 @@ +structure LRS = +struct + datatype direction = Left | Right | Stay +end + +structure LR = +struct + datatype direction = Left | Right +end diff --git a/turingMachine/sources.cm b/turingMachine/sources.cm new file mode 100644 index 0000000..892d364 --- /dev/null +++ b/turingMachine/sources.cm @@ -0,0 +1,7 @@ +Group is + $/basis.cm + stateMachine/sources.cm + tape/sources.cm + turing.sml + turing.sig + directions.sml diff --git a/turingMachine/stateMachine/.cm/GUID/functionsm.sml b/turingMachine/stateMachine/.cm/GUID/functionsm.sml new file mode 100644 index 0000000..942068f --- /dev/null +++ b/turingMachine/stateMachine/.cm/GUID/functionsm.sml @@ -0,0 +1 @@ +guid-(sources.cm):turing/(sources.cm):stateMachine/(sources.cm):functionsm.sml-1468006107.407 diff --git a/turingMachine/stateMachine/.cm/GUID/stateMachine.sig b/turingMachine/stateMachine/.cm/GUID/stateMachine.sig new file mode 100644 index 0000000..5938492 --- /dev/null +++ b/turingMachine/stateMachine/.cm/GUID/stateMachine.sig @@ -0,0 +1 @@ +guid-(sources.cm):turing/(sources.cm):stateMachine/(sources.cm):stateMachine.sig-1468006107.398 diff --git a/turingMachine/stateMachine/.cm/SKEL/functionsm.sml b/turingMachine/stateMachine/.cm/SKEL/functionsm.sml new file mode 100644 index 0000000..b6eafec --- /dev/null +++ b/turingMachine/stateMachine/.cm/SKEL/functionsm.sml @@ -0,0 +1,2 @@ +Skeleton 5 +ae"FunctionSM"i1aOPTIONS"h0jh1egp1gp1c"STATE_MACHINE" \ No newline at end of file diff --git a/turingMachine/stateMachine/.cm/SKEL/stateMachine.sig b/turingMachine/stateMachine/.cm/SKEL/stateMachine.sig new file mode 100644 index 0000000..857a149 --- /dev/null +++ b/turingMachine/stateMachine/.cm/SKEL/stateMachine.sig @@ -0,0 +1,2 @@ +Skeleton 5 +ac"STATE_MACHINE"h0 \ No newline at end of file diff --git a/turingMachine/stateMachine/.cm/x86-unix/functionsm.sml b/turingMachine/stateMachine/.cm/x86-unix/functionsm.sml new file mode 100644 index 0000000000000000000000000000000000000000..eec39a5ee98ba3e1caef12e756ddb61c63340c0e GIT binary patch literal 2452 zcma)7VQ3R)82&C^+q0%xyU03PW_LTJ9k$*jv8~m~lBQl9(PnGV4xQb#O*ErPN|Tsv zsMw}fZr@JJ984IDksm__g4I#nL?KMc5Ap9n*bm!DXXzLN-Ji|*?S1dkG?g)SaNl?D z_kHj4KJW9scc&k8cLb&3+3FaW&cpb5(%B_Uhv@dUdTKn|WdtY>X zGc{ZDO52d1s zcrwhMsPol4$l7f&_q3Rqs(qjTm6FtKl8NQ$jD-xUld_7^; zGqt7wj)Gc`0ssJST)J+<&BlV-gbsQ}GT>yQ*~m2NnXLs?Hl`B6<-=zNKD!#?*2QeRjA@m(VAFu-pfmUMu zKz5KIV3x$Jky#hm=Z)h5)Nfew7xl$tPx~=hm8UT%{ffkHq*Ki0`rl=_D9Fe12U+z2 zfsXPJc%T&6j5PZhpcaEIK7!}zX|rqUsf+dqz%fL7&?87=gdXBSyvuk9u>HWOJYEAd zZmBT8!XfAdvk?SvItRAp<0$uexja7!GJ*WclRLN)>!+t>xyhIt_D}I;LCt1I(LckR zZ6ZL+Kya(%*oifWw5-!~8P;d}_#@x~Q9yp%;{>D$GI(0i9%omdI<3q9|bg6=H(6?J~_ zS6S{m&D@Jz%j*k1#=sNm7l2AX4f24D%z0zx0U$2A;00W)ghn)`J}JjLfXB;pJl6!L zfhU$<73ey>7e6}qnio_DNKD`j)id=p$s4MJ?&DE5vpEEm2|FfRXadF0z)`E0Bw!qb zQiN9IQw2R^r!FkfA?sVQTtKGmT0%hRXD@OH!NOd+u8VwvdqTU;{H0=-^k77c% zZ#CyX68V{VGLwob^SP8Z8t(frHkcR@eNIo_9`@$zIBt-{HHA&CAN0JS49(|~G0{1! ziTLXiy(ForLY91n}0{DufSvn@J!RACb> zzIKn7jql_lPB7S6SGQ@}EOWwbT5Bw8s=~B*%gQ=TtHQD-t4*uYvd%W{2S(ng>>=_$ DE=xs5 literal 0 HcmV?d00001 diff --git a/turingMachine/stateMachine/.cm/x86-unix/stateMachine.sig b/turingMachine/stateMachine/.cm/x86-unix/stateMachine.sig new file mode 100644 index 0000000000000000000000000000000000000000..5069787008906965397e6280d639f9abd4dc32cf GIT binary patch literal 821 zcmZ`%&1(}u6rb7F)V8sdf_hTJ5J4eLcat<9M$|QpribK`96Ts?lHE-L%_d|w8bJ!# zZE_Z`f=G_u;=x;ml!yoENf11y1ws55gy-9Q&_;0B-Pt$4_xpG-k|g>gQIDq?4SR4c zk=b=`QtnLlM}!EAYq`fyJ{`R~+4g?^()oHsC)jk;r$3Wje|zwH_0QhUo5=gl#|z(o z>=hejW&MUxZPW{@;V)Ef-ZC5YvR>SnIWtUds%c&*m38(1h~Fp|*QHQ6DvDuAjQE4G z=-C-kPKNkPulxDJfs+${{w9#~dO-1}UX5L+7BhZl3&+BdaZ9z6ZZ;?9l26leBDI}K zvQR=M1_-7Wt{r!I!7NvGCh`070uhv7J-DKgK20E`lxwPjub`>r!4`mI`341e9Sn#dl41NDTgv zh*)OR?2uwXd&h(d+Bbm&2BZfe@DFGYT0Ur9$Hdl(Mo^~)mTwb (sym, dir, SM (subroutine' act)) + in + subroutine' sm + end +end + diff --git a/turingMachine/stateMachine/sources.cm b/turingMachine/stateMachine/sources.cm new file mode 100644 index 0000000..00f2439 --- /dev/null +++ b/turingMachine/stateMachine/sources.cm @@ -0,0 +1,4 @@ +Group is + $/basis.cm + stateMachine.sig + functionsm.sml diff --git a/turingMachine/stateMachine/stateMachine.sig b/turingMachine/stateMachine/stateMachine.sig new file mode 100644 index 0000000..b5c883d --- /dev/null +++ b/turingMachine/stateMachine/stateMachine.sig @@ -0,0 +1,22 @@ +signature STATE_MACHINE = +sig + (* What to do when the TM has halted *) + type action + (* Direction of the head to move. *) + type direction + + type 'a state + type 'a tapeSymbol + datatype 'a sm = Halt of action | SM of 'a state + type 'a move = 'a tapeSymbol * direction * 'a sm + + (* Exception raised when nextMove is called on a halted sm *) + exception Halted + + (* Determine the next move (incl. symbol to write, direction of tape head, and + * next state) based on current configuration *) + val nextMove : 'a sm -> 'a tapeSymbol -> 'a move + + (* Make subroutines *) + val subroutine : 'a sm -> (action -> 'a tapeSymbol -> 'a move) -> 'a tapeSymbol -> 'a move +end diff --git a/turingMachine/tape/.cm/GUID/biinfinitetape.sml b/turingMachine/tape/.cm/GUID/biinfinitetape.sml new file mode 100644 index 0000000..330c617 --- /dev/null +++ b/turingMachine/tape/.cm/GUID/biinfinitetape.sml @@ -0,0 +1 @@ +guid-(sources.cm):turing/(sources.cm):tape/(sources.cm):biinfinitetape.sml-1468006107.493 diff --git a/turingMachine/tape/.cm/GUID/infinitetape.sml b/turingMachine/tape/.cm/GUID/infinitetape.sml new file mode 100644 index 0000000..33a3bc6 --- /dev/null +++ b/turingMachine/tape/.cm/GUID/infinitetape.sml @@ -0,0 +1 @@ +guid-(sources.cm):turing/(sources.cm):tape/(sources.cm):infinitetape.sml-1468006107.462 diff --git a/turingMachine/tape/.cm/GUID/tape.sig b/turingMachine/tape/.cm/GUID/tape.sig new file mode 100644 index 0000000..c91a429 --- /dev/null +++ b/turingMachine/tape/.cm/GUID/tape.sig @@ -0,0 +1 @@ +guid-(sources.cm):turing/(sources.cm):tape/(sources.cm):tape.sig-1468006107.421 diff --git a/turingMachine/tape/.cm/SKEL/biinfinitetape.sml b/turingMachine/tape/.cm/SKEL/biinfinitetape.sml new file mode 100644 index 0000000..69c19aa --- /dev/null +++ b/turingMachine/tape/.cm/SKEL/biinfinitetape.sml @@ -0,0 +1,2 @@ +Skeleton 5 +d2f1d"List"ae"BiinfiniteTape"jh0gp1c"TAPE" \ No newline at end of file diff --git a/turingMachine/tape/.cm/SKEL/infinitetape.sml b/turingMachine/tape/.cm/SKEL/infinitetape.sml new file mode 100644 index 0000000..b50652c --- /dev/null +++ b/turingMachine/tape/.cm/SKEL/infinitetape.sml @@ -0,0 +1,2 @@ +Skeleton 5 +d2f1d"List"ae"InfiniteTape"jh0gp1c"TAPE" \ No newline at end of file diff --git a/turingMachine/tape/.cm/SKEL/tape.sig b/turingMachine/tape/.cm/SKEL/tape.sig new file mode 100644 index 0000000..95788c6 --- /dev/null +++ b/turingMachine/tape/.cm/SKEL/tape.sig @@ -0,0 +1,2 @@ +Skeleton 5 +ac"TAPE"h0 \ No newline at end of file diff --git a/turingMachine/tape/.cm/x86-unix/biinfinitetape.sml b/turingMachine/tape/.cm/x86-unix/biinfinitetape.sml new file mode 100644 index 0000000000000000000000000000000000000000..a0f8587135b75e12e8a9311c5fc2a71c27f4796e GIT binary patch literal 2664 zcma)8eP|nX7`~*}HrrB@Le)*j7S1s0T(ex$wRO(Xq$wA%+USB*S7_5FX%5;XwuyCP z%(PiL&m$Q3hfI_q{X?gySizyl{^+b8g0O)@7|66$26Z6f*PQz}pZD&Prf~xgE_c6= z_j%vvdEeiA;d!^KqtoGdzO&tdYdym-HMmWeFi24ft7@&Lb55RY*a6;{7}a* z#iEAO^+_3s!$hxAZzixYfW4oErIduFrI2KEiXE13!BV%&mh5atU)6(xE&0-I-9Uk@ zB3M@Ep4aBAavalk%?-tzZDX-jXp(y@lCV(`Hm|N+ucZ}-JkClx!#Tr{vpOiPKK$0#*2IRQq$``bj@fd~DW!1xm3+#&^iXo^r z0Mve{9mF$&XGr5Br>r`1#;sc;QZW8srd7BKFewi8k`YH7JV6`s5gvtsa6;G?q;03^ zM~fkMqsEp$i&2@1Eq{!L8Ai(sN{zygvj)!x4E&U}9IVE1mEXWE_%&DYyS<6ds~=8D zD-BBvwwf5_(;!yjULvP!8@CW)NK7Sx_{k+|_fHf=xpu$4R&fRblzD^QxN%lVCPlE) z36!Sn(qI#cL9QzdQU!r#0NA|%Mxh-?6;VA!oPm{BbRUJ;cqRUQ1~#3s56{sV*Rm~p zh{k@SpKPGYrGA!mSJ>K)7AYlE-_Y5}glL>u>Tcz}qBW2#4jKwwK~n*o-s_~Pjnd#| zsm~$zqI#dzSTq&-tP%|$TO~uatr2~W6Fp}u@ni8>CTWWbOB2Gj{(qb~f@nPQr%4?WOgy&V)u(yUEQMY;`OLM)^ zSejd85_o-59F61MMDP33;RD>F8GkHd-!L`qm3eh*j8R=Fb=tgZ1V8DeMMiB`r?2>P#wpap74YbsdR;Tx<(|498H__xKebS*#Cfx1?22rwzl283Kw`U?cnHfv(OHb_O zT73!MuXELZPdJ82EY!j-=B!abfi$8&M66}N};EG;CuxiN7v&CM?@n&#Cb+gCnP^L8~?tLE3Kvt~8lq2{e3 sKgJirO@gm^6O|e!CV55!9#>l3PYV=Xw0Vtp7_A>5&0R)MO`2YX_ literal 0 HcmV?d00001 diff --git a/turingMachine/tape/.cm/x86-unix/infinitetape.sml b/turingMachine/tape/.cm/x86-unix/infinitetape.sml new file mode 100644 index 0000000000000000000000000000000000000000..f82939e0bf4814bb630d92162e4f9f9d17e82cd3 GIT binary patch literal 2632 zcmb7GZ)h837=M%A+N@326ssHBjc|rhS=Z&7t}SzprcJpF>snoq!U}ELBu${bWbK7+ zGDg}go#$~{_dx_{r%PB_LpsTk|t*k-2ByX|HcnL?>_w1#&cC? zO2;N{;a4iWnJ-eQuTnRE?<@bVw)XO!TX$c)@#l|cw~wY1k(~{b$@IiXbh2q={Fyy+ zdLki>?pi+=PDR(xB&1kEO2|^YG)^@MARq(bowX`-2J z$8b6>7Jzt6^yn3K3N{9?_cO3mlCX4WNiM6qVEH;MO}k9quIA)hW>B!DzD!#$P++Tz zj<4qL@KwcDYHTXeC0ZROeqy5d&HIVI`Q#Rj|GqSB}(ol4TH ziFJzDq9xr*vRxPVnoJuNu|rFCWc488{Rs#x-pn@-3?m=%)KgZd)c@It87kxGfX#W> zFlEa@r4JJkOw3t&WnO(G&U+;|!v)`=Vw;_c?CDo!PpBwwnZKwll9Y5PQ%*#J^?piiCSaeL{I4k>j(*sL%^nDQ2&?Ah3x&Zn%osiAs=*2 z?$kpVS#;Ao{>zB5Sz|Kr5GD;JOdf4wGU!LJR27D0MQS;YBUe`H%#01?S>oA8Ntr6H zCmg56GK4a{MXP}JhRn6QMYSHpT>e;(TW6AD>7tXKG-b-A4A!Aw)N*Z*Rth)*GeS^D52JsEVkstz+2by}}ep~Dx}$c(Ww z2SO(RlGPh1p;C3NY^}_w|Po}$Ze0h`Vo~E ztf0py@W!;OEW&(Jo#fOqQ0`NocdCb2`R0AEz_ie7>Wh7Jnt7aIspF^%G*>f&PG!(# zWso+H^%?9y%g$$zo(AOa(>q16ugl*NY<@`oZXU?%(Z#Zb?gW7cpgBEo=wvL8Ue^?G6qOJeHtN;+qhn6h<)@ch69c-kJ9VZdRY-+ zi)v${`6&ZGXiVmph=kXd5~Fdv+vxj2Iee5~vg40K z>|0XiU0pD?#)#3FGN#Gy5&X!@OT=g~rW?G*bcHePiAh+hqDxh>F}=r_ek?z^nNDst zC%3Ul$?IJth>}B;Lh9Q5-ihdBdQ3hjPweBHJEhJ)=1c#6@PtT<8(=iUx=Kk)bZ zuWtXn`i)n3ZefKi$O&O(p6Yz?==gAQjHgzWu&TC&yM1w9;NyHVZXfSkUX;4{vBadz zFDx(F7K{@Os~;MFvnCqDs86vw`17x>#jS5dW`(8#M^Z&Eg4F5w^6#l2EcuXh(nFu04 zhA=R&7#2KU6yg}*s$}Bq$WZ*BsU*$3;L#$Gg5b*Br2HHu!$fCC7RE%!Jf{LB-bC9O zA+G-%{T*+rz2oh#QexToh{3Sr<;MRaX$%J$ff`dXi&B$IGV}9*`kWkD8JJRll8wAT zSte(wxnLPKMu?0KP=>i6Q7O5!s3D?k(nkNAl%cdfm`-$IF#O-B@xM{g w04T)>)Rmc+S%RzsY*kKXaf#A@d!P~~ppue&9}pki*cLX!|4sVLet8B40L#+6`v3p{ literal 0 HcmV?d00001 diff --git a/turingMachine/tape/biinfinitetape.sml b/turingMachine/tape/biinfinitetape.sml new file mode 100644 index 0000000..49fbbb8 --- /dev/null +++ b/turingMachine/tape/biinfinitetape.sml @@ -0,0 +1,31 @@ +(* Only works with LRS *) +functor BiinfiniteTape(datatype direction = Left | Right | Stay) : TAPE = +struct + type direction = direction + type 'a tapeSymbol = 'a option + + (* Both left and right tapes are stacks of symbols closest + * to the current symbol. If a tape = L * current * R, then + * the in-order tape looks like: (rev L) @ (current :: R) + *) + type 'a tape = 'a tapeSymbol list * 'a tapeSymbol * 'a tapeSymbol list + val currentSymbol : 'a tape -> 'a tapeSymbol = #2 + + (* Bi-infinite tape, so if we try to go left from the leftmost position, + * extend tape to the left. Do the same for the right. *) + fun makeMove (L, _, R) symbol Stay = (L, symbol, R) + (* Extend tape if necessary *) + | makeMove ([], _, R) symbol Left = ([], NONE, symbol :: R) + | makeMove (L, _, []) symbol Right = (symbol :: L, NONE, []) + (* Discard unneeded blanks at either end *) + | makeMove (l :: ls, _, []) NONE Left = (ls, l, []) + | makeMove ([], _, r :: rs) NONE Right = ([], r, rs) + (* Actually make move *) + | makeMove (l :: ls, _, R) symbol Left = (ls, l, symbol :: R) + | makeMove (L, _, r :: rs) symbol Right = (symbol :: L, r, rs) + + fun init [] = ([], NONE, []) + | init (symbol :: symbols) = ([], SOME symbol, map SOME symbols) + + fun toList (L, current, R) = List.revAppend (L, current :: R) +end diff --git a/turingMachine/tape/infinitetape.sml b/turingMachine/tape/infinitetape.sml new file mode 100644 index 0000000..ea11e02 --- /dev/null +++ b/turingMachine/tape/infinitetape.sml @@ -0,0 +1,32 @@ +(* Only works with LRS *) +functor InfiniteTape(datatype direction = Left | Right | Stay) : TAPE = +struct + type direction = direction + type 'a tapeSymbol = 'a option + + (* Both left and right tapes are stacks of symbols closest + * to the current symbol. If a tape = L * current * R, then + * the in-order tape looks like: (rev L) @ (current :: R) + *) + type 'a tape = 'a tapeSymbol list * 'a tapeSymbol * 'a tapeSymbol list + val currentSymbol : 'a tape -> 'a tapeSymbol = #2 + + (* Infinite tape, so if we try to go left from the leftmost position, + * stay there. For right, extend tape. *) + fun makeMove (L, _, R) symbol Stay = (L, symbol, R) + (* Loop back *) + | makeMove ([], _, R) symbol Left = ([], symbol, R) + (* Extend tape if necessary *) + | makeMove (L, _, []) symbol Right = (symbol :: L, NONE, []) + (* These next two cases discard unneeded blanks at either end *) + | makeMove (l :: ls, _, []) NONE Left = (ls, l, []) + | makeMove ([], _, r :: rs) NONE Right = ([], r, rs) + (* These next two cases actually move left and right *) + | makeMove (l :: ls, _, R) symbol Left = (ls, l, symbol :: R) + | makeMove (L, _, r :: rs) symbol Right = (symbol :: L, r, rs) + + fun init [] = ([], NONE, []) + | init (symbol :: symbols) = ([], SOME symbol, map SOME symbols) + + fun toList (L, current, R) = List.revAppend (L, current :: R) +end diff --git a/turingMachine/tape/sources.cm b/turingMachine/tape/sources.cm new file mode 100644 index 0000000..dd40fd0 --- /dev/null +++ b/turingMachine/tape/sources.cm @@ -0,0 +1,5 @@ +Group is + $/basis.cm + tape.sig + infinitetape.sml + biinfinitetape.sml diff --git a/turingMachine/tape/tape.sig b/turingMachine/tape/tape.sig new file mode 100644 index 0000000..b04e28f --- /dev/null +++ b/turingMachine/tape/tape.sig @@ -0,0 +1,15 @@ +signature TAPE = +sig + (* Add exactly 1 symbol to the tape alphabet: the blank symbol (NONE) *) + type 'a tapeSymbol = 'a option + type direction + + type 'a tape + val currentSymbol : 'a tape -> 'a tapeSymbol + (* Write tapeSymbol on current position of tape, then move in direction *) + val makeMove : 'a tape -> 'a tapeSymbol -> direction -> 'a tape + + (* Create a new tape, drawing only from the input alphabet *) + val init : 'a list -> 'a tape + val toList : 'a tape -> 'a tapeSymbol list +end diff --git a/turingMachine/turing.sig b/turingMachine/turing.sig new file mode 100644 index 0000000..e7fc885 --- /dev/null +++ b/turingMachine/turing.sig @@ -0,0 +1,13 @@ +signature TURING_MACHINE = +sig + structure T : TAPE + structure SM : STATE_MACHINE + where type 'a tapeSymbol = 'a T.tapeSymbol + sharing type T.direction = SM.direction + + (* Simulate a single step on the turing machine *) + val step : 'a SM.sm -> 'a T.tape -> 'a SM.sm * 'a T.tape + + (* Simulate the turing machine until it halts. *) + val simulate : 'a SM.sm -> 'a list -> SM.action * 'a T.tapeSymbol list +end diff --git a/turingMachine/turing.sml b/turingMachine/turing.sml new file mode 100644 index 0000000..c5dffef --- /dev/null +++ b/turingMachine/turing.sml @@ -0,0 +1,27 @@ +functor Turing ( + structure T : TAPE + structure SM : STATE_MACHINE + where type 'a tapeSymbol = 'a T.tapeSymbol + sharing type T.direction = SM.direction) : TURING_MACHINE = +struct + structure T = T + structure SM = SM + + (* Simulate 1 step on the stateMachine and tape *) + fun step stateMachine tape = + let + val symbol = T.currentSymbol tape + val (newSymbol, direction, stateMachine') = + SM.nextMove stateMachine symbol + val tape' = T.makeMove tape newSymbol direction + in + (stateMachine', tape') + end + + (* Simulate until halt *) + fun simulate' (SM.Halt action, tape) = (action, tape) + | simulate' (sm, tape) = simulate' (step sm tape) + fun simulate stateMachine input = + case simulate' (stateMachine, T.init input) + of (action, tape) => (action, T.toList tape) +end