currnet code
authorChengsong
Thu, 07 May 2020 11:36:15 +0100
changeset 150 b51d34113d47
parent 149 6c5920fd02a7
child 151 73f990bc6843
currnet code
Spiral.scala
lex_blex_Frankensteined.scala
--- a/Spiral.scala	Thu Apr 16 09:14:15 2020 +0100
+++ b/Spiral.scala	Thu May 07 11:36:15 2020 +0100
@@ -2,7 +2,6 @@
 import RexpRelated._
 import RexpRelated.Rexp._
 import Partial._
-import BRexp._
 import scala.collection.mutable.ListBuffer
 object Spiral{
 
@@ -27,7 +26,6 @@
     }
   }
   val alphabet = ("""abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789.:"=()\;-+*!<>\/%{} """+"\n\t").toSet//Set('a','b','c')
-  def bregx_tree(r: BRexp): Element = regx_tree(berase(r))
   def regx_tree(r: Rexp): Element = aregx_tree(internalise(r))
   def annotated_tree(r: ARexp): Element = {
     r match {
@@ -371,42 +369,7 @@
     }
   }
   val mkst = "abcdefghijklmnopqrstuvwxyz"
-  def weak_sub_check(r: Rexp, s: String, i: Int, f: (List[Rexp], Set[Rexp]) => Boolean){
-    //we first compute pders over the set of all strings on the alphabet
-    val pd = pderas(Set(r), i + 4)
-    //then "b-internalise" the regular expression into a brexp(this is essentially 
-    //attaching a bit Z to every alts to signify that they come from the original regular expression)
-    var old = brternalise(r)
-    //this is for comparison between normal simp and the weakened version of simp
-    //normal simp will be performed on syncold
-    //weakend simp will be performed on old
-    var syncold = internalise(r)
-    val all_chars = s.toList
-    for (i <- 0 to s.length - 1){
-      val syncder_res = bder(all_chars(i), syncold)
-      val syncsimp_res = super_bsimp(syncder_res)
-      //see brder for detailed explanation
-      //just changes bit Z to S when deriving an ALTS, 
-      //signifying that the structure has been "touched" and
-      //therefore able to be spilled in the bspill function
-      val der_res =  brder(all_chars(i), old)
-      val simp_res = br_simp(der_res)
-      val anatomy = bspill(simp_res)
-      //track if the number of regular expressions exceeds those in the PD set(remember PD means the pders over A*)
-      if(f(List(berase(simp_res)), pd)  == false ){
-        println(size(erase(syncsimp_res)))
-        println(size(berase(simp_res)))
-        println(bregx_tree(simp_res))
-        println(s)
-        println(i)
-        println(r)
-        println(anatomy.map(size).sum)
-        println(pd.map(size).sum)
-      }  
-      old = simp_res
-      syncold = syncsimp_res
-    }
-  }
+  
   def inclusion_truth(anatomy: List[Rexp], pd: Set[Rexp]): Boolean = {
     val aset = anatomy.toSet
     if(aset subsetOf pd){
@@ -427,11 +390,7 @@
   }
   val big_panda = STAR(STAR(STAR(ALTS(List(ALTS(List(CHAR('c'), CHAR('b'))), SEQ(CHAR('c'),CHAR('c')))))))
   val str_panda = "ccccb"
-  def check_all(){
 
-        weak_sub_check(big_panda, str_panda, 6, size_expansion_rate)
-
-  }
   def bstostick(bs: List[Bit]): Element = bs match {
     //case b::Nil => elem(b.toString)
     case b::bs1 => elem(b.toString) beside bstostick(bs1)
--- a/lex_blex_Frankensteined.scala	Thu Apr 16 09:14:15 2020 +0100
+++ b/lex_blex_Frankensteined.scala	Thu May 07 11:36:15 2020 +0100
@@ -641,7 +641,7 @@
   //given the number of right outside it
   def coat(v: Val, i: Int) : Val = i match {
     case 0 => v
-    case i => coat(Right(v), i - 1)
+    case i => if(i > 0) coat(Right(v), i - 1) else {println(v,i); throw new Exception("coat minus")}
   }
   def decoat(v:Val, i: Int) : Val = i match {
     case 0 => v
@@ -752,7 +752,151 @@
     case (r, v) => (v => v)
   }
   //This version takes a regex and a value, return a simplified regex and its corresponding simplified value 
-  def bsimp2(r: ARexp, v: Val): (ARexp, Val) = (r,v) match{
+  //def flats2(r: Arexp, v: val): (ARexp, Val) = (r, v) match{
+  //  case (AALTS(bs, rs), Right(v0)) => rs match {
+  //    case Nil => (AALTS(bs, Nil), v)
+  //    case AZERO::rs0 =>  flats2(AALTS(bs, rs0), v0) 
+  //    case 
+  //  case (AALTS(bs, rs), Left(v0)) => 
+  //}
+  //liangren qixinxieli zuo yixie shiqing 
+  //shi xinzhaobuxuan de moqi
+  //ni yao fanzhangben 
+  //na wo jiu zhineng peini fanzhangben 
+  //ni xianshuo wo weini zuole haoduohaoduo
+  //na wo jiu haohao gen ni fenxifenxi
+  //ni daodi zuole shenme 
+  //ni meizuo shenme 
+  //zhishi yinwei ni lei 
+  //suoyi ni juede ni zuole haoduo 
+  //zuofanyeshi 
+  //shi weile ni shiwu cai zuo name jingxi
+  //shiwo de hua meitian sancan huadeshijian 
+  //buchaoguo liangxiaoshi
+  //ni zuode henduoshihou doushi weile ziji
+  //ni zuoshiqing de shihou ye zongshi bawo jiaolai bangmang
+  //ni de xiaolv hai hendi 
+  //zonghe kanlai
+  //ni buhuizhaoguziji meiyoudandang nenglibuzu haizisi
+  //suoyi wo zui taoyan gennishuozhexie 
+  //shuoli bianbuguolai 
+  //jiu ba ren xiaoshihoude shiqing nachulaishuo, lai exin ren
+  //nibangwo daoyibeishui, wo buleyujieshou, wo bushuoxiexie 
+  //nandao woshuo sheiyaonidaole, zoukai? buyaoni geiwo dao? wo ziji dao?
+  //nishuo qiantou doushi ni zaizuo 
+  //zheliwoyao buchong
+  //quancheng ni yigerenzuo yidunfan de cishu
+  //dagai you duoshaoci?
+  //kending you jici, dan bushi duoshu
+  //duoshu shi wo huilai yihou 
+  //ni rangwo lai chaocai huozhe lai jieguan zuowan shengyude gongzuo 
+  //ni zuo de zhexieshihou 
+  //yiban jiushi lianggecai 
+  //huozhe yicai yitang
+  //wo hui renwei 
+  //zhe shi ni shenti keyi shiying de gongzuoliang
+  //moren ni ziji hui zhaoguhao ziji 
+  //ruguo ni leile, yehui lai zhaowo bangmang
+  //suoyi wo moren ni zai zhe qijian shi meiyou
+  //guolao, ruguo you, wo renwei 
+  //1 ni meiyou zhaoguhao niziji
+  //2 nimeiyou jishi xiangwo xunqiu bangzhu
+  //3 ni jibensangshi laodongnengli le,
+  //yihou huolu doushi wo lai bao le jiu wanle
+  //niziji meinengli jiu buyao dui zuoshi de ren 
+  //tiaosanjiansi
+  //ni shibushi taomi xigecai jiu hui lei
+  //na shuoming
+  //yaome ni tili taicha--jibensangshi laodongli
+  //yaome ni fangfabuheshi(xiaolvdi, zishiyouwenti daozhi shentilaosun)--ni yinggai tiaozheng ziji zuoshide fangfa, women yiqilai zhaozhao yuanyin
+  //cuowu de silushi: nikanwo dou zhemelei le,
+  //shuoming wo zuole henduo, ni bu tiliangwo
+  //ni zuo zhexie doushi yinggaide
+  //yinwei wo shi nimama erqie wo leile
+  def pos_i(rs: List[ARexp], v: Val): Int = (rs, v) match {
+    case (r::Nil,         v1) => 0
+    case ( r::rs1, Right(v) ) => pos_i(rs1, v) + 1
+    case ( r::rs1, Left(v)  ) => 0
+  }
+  def pos_v(rs: List[ARexp], v: Val): Val = (rs, v) match {
+    case (r::Nil,         v1) => v1
+    case (r::rs1, Right(v)  ) => pos_v(rs1, v)
+    case (r::rs1, Left(v)   ) => v
+  }
+  def unify(rs: List[ARexp], v: Val): Val = {
+    Position( pos_i(rs, v), pos_v(rs, v) )
+  }
+  def deunify(rs_length: Int, v: Val): Val = v match{
+    case Position(i, v0) => {
+      if(i <0) {println(rs_length, v); throw new Exception("deunify minus")} 
+      else if(rs_length == 1) {println(v); v}
+      else if(rs_length - 1 == i) coat(v0, i) 
+      else coat(Left(v0), i)
+      }
+    case _ => throw new Exception("deunify error")
+  }
+  def flats2(front: List[ARexp], i: Int, rs: List[ARexp], v: Val): (List[ARexp], Val) = v match {
+    case Position(j, v0) => {
+      if (i < 0) (front ::: flats(rs), Position(j, v0) ) 
+      else if(i == 0){
+        rs match {
+          case AALTS(bs, rs1) :: rs2 => ( (front ::: rs1.map(fuse(bs, _))):::flats(rs2), Position(j + rs1.length - 1, pos_v(rs1, v0)))
+          case r::rs2 => (front ::: List(r) ::: flats(rs2), Position(j, v0))
+          case _ => throw new Exception("flats2 i = 0")
+        }
+      }
+      else{
+        rs match {
+          case AZERO::rs1 => flats2(front, i - 1, rs1, Position(j - 1, v0))
+          case AALTS(bs, rs1) ::rs2 => flats2(front:::rs1.map(fuse(bs, _)), i - 1, rs2, Position(j + rs1.length - 1, v0))
+          case r::rs1 => flats2(front:::List(r), i - 1, rs1, Position(j, v0)) 
+          case _ => throw new Exception("flats2 i>0")
+        }
+      }
+    }
+    case _ => throw new Exception("flats2 error")
+  }
+  def distinctBy2[B, C](v: Val, xs: List[B], f: B => C, acc: List[C] = Nil, res: List[B] = Nil): (List[B], Val) = xs match {
+    case Nil => (res, v)
+    case (x::xs) => {
+      val re = f(x)
+      if (acc.contains(re)) v match { 
+        case Position(i, v0) => distinctBy2(Position(i - 1, v0), xs, f, acc, res)  
+        case _ => throw new Exception("dB2")
+      }
+      else distinctBy2(v, xs, f, re::acc, x::res)
+    }
+  }
+   def bsimp2(r: ARexp, v: Val): (ARexp, Val) = (r,v) match{
+    case (ASEQ(bs1, r1, r2), Sequ(v1, v2)) => (bsimp2(r1, v1), bsimp2(r2, v2)) match {
+        case ((AZERO, _), (_, _) )=> (AZERO, undefined)
+        case ((_, _), (AZERO, _)) => (AZERO, undefined)
+        case ((AONE(bs2), v1s) , (r2s, v2s)) => (fuse(bs1 ++ bs2, r2s), v2s )//v2 tells how to retrieve bits in r2s, which is enough as the bits of the first part of the sequence has already been integrated to the top level of the second regx.
+        case ((r1s, v1s), (r2s, v2s)) => (ASEQ(bs1, r1s, r2s),  Sequ(v1s, v2s))
+    }
+    case (AALTS(bs1, rs), v) => {
+      val vlist = unify(rs, v)
+      vlist match {
+        case Position(i, v0) => {
+          val v_simp = bsimp2(rs(i), v0)._2
+          val rs_simp = rs.map(bsimp)
+          val flat_res = flats2( Nil, i, rs_simp, Position(i, v_simp) )
+          val dist_res = distinctBy2(flat_res._2, flat_res._1, erase)
+          val rs_new = dist_res._1
+          val v_new = deunify(rs_new.length, dist_res._2)
+          rs_new match {
+            case Nil => (AZERO, undefined)
+            case s :: Nil => (fuse(bs1, s), v_new)
+            case rs => (AALTS(bs1, rs), v_new)
+          }
+        }
+        case _ => throw new Exception("Funny vlist bsimp2")
+      }
+    }
+    //case ASTAR(bs, r) => ASTAR(bs, bsimp(r))
+    case (r, v) => (r, v)  
+  }
+  /*def bsimp2(r: ARexp, v: Val): (ARexp, Val) = (r,v) match{
     case (ASEQ(bs1, r1, r2), Sequ(v1, v2)) => (bsimp2(r1, v1), bsimp2(r2, v2)) match {
         case ((AZERO, _), (_, _) )=> (AZERO, undefined)
         case ((_, _), (AZERO, _)) => (AZERO, undefined)
@@ -794,7 +938,7 @@
     }
     //case ASTAR(bs, r) => ASTAR(bs, bsimp(r))
     case (r, v) => (r, v)  
-  }
+  }*/
   //the below are all residuals from the bsimp2 function 
         //val vs_for_coating = if(isend(vs._2, rs_simp, init_ind)||flat_res.length == 1) vs_kernel else Left(vs_kernel)
         //val vf = coat(vs_for_coating, new_ind)
@@ -857,7 +1001,8 @@
     //case ASTAR(bs, r) => ASTAR(bs, bsimp(r))
     case r => r
   }
-
+//nice website http://www.nhc.gov.cn/xcs/kpzs/202002/d228d85eaa19412eaaa4eee740f03101.shtml
+//orientalism
 
   def simp_weakened(r: Rexp): Rexp = r match {
     case SEQ(r1, r2) => (simp_weakened(r1), r2) match {
@@ -1219,6 +1364,7 @@
 case class Right(v: Val) extends Val
 case class Stars(vs: List[Val]) extends Val
 case class Rec(x: String, v: Val) extends Val
+case class Position(i: Int, v: Val) extends Val
 case object undefined extends Val
 //case class Pos(i: Int, v: Val) extends Val
 case object Prd extends Val