thys2/PositionsExt.thy
author Chengsong
Mon, 10 Jul 2023 19:29:22 +0100
changeset 664 ba44144875b1
parent 365 ec5e4fe4cc70
permissions -rw-r--r--
introduction Contribution section update
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
365
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
     1
   
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
     2
theory PositionsExt
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
     3
  imports "SpecExt" "LexerExt" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
     4
begin
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
     5
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
     6
section {* Positions in Values *}
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
     7
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
     8
fun 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
     9
  at :: "val \<Rightarrow> nat list \<Rightarrow> val"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    10
where
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    11
  "at v [] = v"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    12
| "at (Left v) (0#ps)= at v ps"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    13
| "at (Right v) (Suc 0#ps)= at v ps"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    14
| "at (Seq v1 v2) (0#ps)= at v1 ps"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    15
| "at (Seq v1 v2) (Suc 0#ps)= at v2 ps"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    16
| "at (Stars vs) (n#ps)= at (nth vs n) ps"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    17
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    18
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    19
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    20
fun Pos :: "val \<Rightarrow> (nat list) set"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    21
where
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    22
  "Pos (Void) = {[]}"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    23
| "Pos (Char c) = {[]}"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    24
| "Pos (Left v) = {[]} \<union> {0#ps | ps. ps \<in> Pos v}"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    25
| "Pos (Right v) = {[]} \<union> {1#ps | ps. ps \<in> Pos v}"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    26
| "Pos (Seq v1 v2) = {[]} \<union> {0#ps | ps. ps \<in> Pos v1} \<union> {1#ps | ps. ps \<in> Pos v2}" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    27
| "Pos (Stars []) = {[]}"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    28
| "Pos (Stars (v#vs)) = {[]} \<union> {0#ps | ps. ps \<in> Pos v} \<union> {Suc n#ps | n ps. n#ps \<in> Pos (Stars vs)}"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    29
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    30
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    31
lemma Pos_stars:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    32
  "Pos (Stars vs) = {[]} \<union> (\<Union>n < length vs. {n#ps | ps. ps \<in> Pos (vs ! n)})"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    33
apply(induct vs)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    34
apply(auto simp add: insert_ident less_Suc_eq_0_disj)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    35
done
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    36
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    37
lemma Pos_empty:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    38
  shows "[] \<in> Pos v"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    39
by (induct v rule: Pos.induct)(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    40
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    41
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    42
abbreviation
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    43
  "intlen vs \<equiv> int (length vs)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    44
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    45
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    46
definition pflat_len :: "val \<Rightarrow> nat list => int"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    47
where
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    48
  "pflat_len v p \<equiv> (if p \<in> Pos v then intlen (flat (at v p)) else -1)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    49
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    50
lemma pflat_len_simps:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    51
  shows "pflat_len (Seq v1 v2) (0#p) = pflat_len v1 p"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    52
  and   "pflat_len (Seq v1 v2) (Suc 0#p) = pflat_len v2 p"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    53
  and   "pflat_len (Left v) (0#p) = pflat_len v p"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    54
  and   "pflat_len (Left v) (Suc 0#p) = -1"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    55
  and   "pflat_len (Right v) (Suc 0#p) = pflat_len v p"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    56
  and   "pflat_len (Right v) (0#p) = -1"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    57
  and   "pflat_len (Stars (v#vs)) (Suc n#p) = pflat_len (Stars vs) (n#p)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    58
  and   "pflat_len (Stars (v#vs)) (0#p) = pflat_len v p"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    59
  and   "pflat_len v [] = intlen (flat v)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    60
by (auto simp add: pflat_len_def Pos_empty)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    61
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    62
lemma pflat_len_Stars_simps:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    63
  assumes "n < length vs"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    64
  shows "pflat_len (Stars vs) (n#p) = pflat_len (vs!n) p"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    65
using assms
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    66
apply(induct vs arbitrary: n p)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    67
apply(auto simp add: less_Suc_eq_0_disj pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    68
done
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    69
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    70
lemma pflat_len_outside:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    71
  assumes "p \<notin> Pos v1"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    72
  shows "pflat_len v1 p = -1 "
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    73
using assms by (simp add: pflat_len_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    74
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    75
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    76
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    77
section {* Orderings *}
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    78
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    79
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    80
definition prefix_list:: "'a list \<Rightarrow> 'a list \<Rightarrow> bool" ("_ \<sqsubseteq>pre _" [60,59] 60)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    81
where
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    82
  "ps1 \<sqsubseteq>pre ps2 \<equiv> \<exists>ps'. ps1 @ps' = ps2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    83
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    84
definition sprefix_list:: "'a list \<Rightarrow> 'a list \<Rightarrow> bool" ("_ \<sqsubset>spre _" [60,59] 60)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    85
where
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    86
  "ps1 \<sqsubset>spre ps2 \<equiv> ps1 \<sqsubseteq>pre ps2 \<and> ps1 \<noteq> ps2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    87
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    88
inductive lex_list :: "nat list \<Rightarrow> nat list \<Rightarrow> bool" ("_ \<sqsubset>lex _" [60,59] 60)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    89
where
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    90
  "[] \<sqsubset>lex (p#ps)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    91
| "ps1 \<sqsubset>lex ps2 \<Longrightarrow> (p#ps1) \<sqsubset>lex (p#ps2)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    92
| "p1 < p2 \<Longrightarrow> (p1#ps1) \<sqsubset>lex (p2#ps2)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    93
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    94
lemma lex_irrfl:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    95
  fixes ps1 ps2 :: "nat list"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    96
  assumes "ps1 \<sqsubset>lex ps2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    97
  shows "ps1 \<noteq> ps2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    98
using assms
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
    99
by(induct rule: lex_list.induct)(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   100
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   101
lemma lex_simps [simp]:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   102
  fixes xs ys :: "nat list"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   103
  shows "[] \<sqsubset>lex ys \<longleftrightarrow> ys \<noteq> []"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   104
  and   "xs \<sqsubset>lex [] \<longleftrightarrow> False"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   105
  and   "(x # xs) \<sqsubset>lex (y # ys) \<longleftrightarrow> (x < y \<or> (x = y \<and> xs \<sqsubset>lex ys))"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   106
by (auto simp add: neq_Nil_conv elim: lex_list.cases intro: lex_list.intros)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   107
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   108
lemma lex_trans:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   109
  fixes ps1 ps2 ps3 :: "nat list"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   110
  assumes "ps1 \<sqsubset>lex ps2" "ps2 \<sqsubset>lex ps3"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   111
  shows "ps1 \<sqsubset>lex ps3"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   112
using assms
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   113
by (induct arbitrary: ps3 rule: lex_list.induct)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   114
   (auto elim: lex_list.cases)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   115
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   116
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   117
lemma lex_trichotomous:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   118
  fixes p q :: "nat list"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   119
  shows "p = q \<or> p \<sqsubset>lex q \<or> q \<sqsubset>lex p"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   120
apply(induct p arbitrary: q)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   121
apply(auto elim: lex_list.cases)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   122
apply(case_tac q)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   123
apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   124
done
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   125
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   126
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   127
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   128
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   129
section {* POSIX Ordering of Values According to Okui \& Suzuki *}
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   130
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   131
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   132
definition PosOrd:: "val \<Rightarrow> nat list \<Rightarrow> val \<Rightarrow> bool" ("_ \<sqsubset>val _ _" [60, 60, 59] 60)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   133
where
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   134
  "v1 \<sqsubset>val p v2 \<equiv> pflat_len v1 p > pflat_len v2 p \<and>
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   135
                   (\<forall>q \<in> Pos v1 \<union> Pos v2. q \<sqsubset>lex p \<longrightarrow> pflat_len v1 q = pflat_len v2 q)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   136
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   137
lemma PosOrd_def2:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   138
  shows "v1 \<sqsubset>val p v2 \<longleftrightarrow> 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   139
         pflat_len v1 p > pflat_len v2 p \<and>
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   140
         (\<forall>q \<in> Pos v1. q \<sqsubset>lex p \<longrightarrow> pflat_len v1 q = pflat_len v2 q) \<and>
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   141
         (\<forall>q \<in> Pos v2. q \<sqsubset>lex p \<longrightarrow> pflat_len v1 q = pflat_len v2 q)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   142
unfolding PosOrd_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   143
apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   144
done
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   145
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   146
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   147
definition PosOrd_ex:: "val \<Rightarrow> val \<Rightarrow> bool" ("_ :\<sqsubset>val _" [60, 59] 60)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   148
where
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   149
  "v1 :\<sqsubset>val v2 \<equiv> \<exists>p. v1 \<sqsubset>val p v2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   150
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   151
definition PosOrd_ex_eq:: "val \<Rightarrow> val \<Rightarrow> bool" ("_ :\<sqsubseteq>val _" [60, 59] 60)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   152
where
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   153
  "v1 :\<sqsubseteq>val v2 \<equiv> v1 :\<sqsubset>val v2 \<or> v1 = v2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   154
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   155
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   156
lemma PosOrd_trans:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   157
  assumes "v1 :\<sqsubset>val v2" "v2 :\<sqsubset>val v3"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   158
  shows "v1 :\<sqsubset>val v3"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   159
proof -
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   160
  from assms obtain p p'
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   161
    where as: "v1 \<sqsubset>val p v2" "v2 \<sqsubset>val p' v3" unfolding PosOrd_ex_def by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   162
  then have pos: "p \<in> Pos v1" "p' \<in> Pos v2" unfolding PosOrd_def pflat_len_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   163
    by (smt not_int_zless_negative)+
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   164
  have "p = p' \<or> p \<sqsubset>lex p' \<or> p' \<sqsubset>lex p"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   165
    by (rule lex_trichotomous)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   166
  moreover
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   167
    { assume "p = p'"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   168
      with as have "v1 \<sqsubset>val p v3" unfolding PosOrd_def pflat_len_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   169
      by (smt Un_iff)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   170
      then have " v1 :\<sqsubset>val v3" unfolding PosOrd_ex_def by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   171
    }   
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   172
  moreover
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   173
    { assume "p \<sqsubset>lex p'"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   174
      with as have "v1 \<sqsubset>val p v3" unfolding PosOrd_def pflat_len_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   175
      by (smt Un_iff lex_trans)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   176
      then have " v1 :\<sqsubset>val v3" unfolding PosOrd_ex_def by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   177
    }
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   178
  moreover
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   179
    { assume "p' \<sqsubset>lex p"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   180
      with as have "v1 \<sqsubset>val p' v3" unfolding PosOrd_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   181
      by (smt Un_iff lex_trans pflat_len_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   182
      then have "v1 :\<sqsubset>val v3" unfolding PosOrd_ex_def by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   183
    }
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   184
  ultimately show "v1 :\<sqsubset>val v3" by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   185
qed
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   186
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   187
lemma PosOrd_irrefl:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   188
  assumes "v :\<sqsubset>val v"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   189
  shows "False"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   190
using assms unfolding PosOrd_ex_def PosOrd_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   191
by auto
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   192
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   193
lemma PosOrd_assym:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   194
  assumes "v1 :\<sqsubset>val v2" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   195
  shows "\<not>(v2 :\<sqsubset>val v1)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   196
using assms
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   197
using PosOrd_irrefl PosOrd_trans by blast 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   198
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   199
(*
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   200
  :\<sqsubseteq>val and :\<sqsubset>val are partial orders.
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   201
*)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   202
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   203
lemma PosOrd_ordering:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   204
  shows "ordering (\<lambda>v1 v2. v1 :\<sqsubseteq>val v2) (\<lambda> v1 v2. v1 :\<sqsubset>val v2)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   205
unfolding ordering_def PosOrd_ex_eq_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   206
apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   207
using PosOrd_irrefl apply blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   208
using PosOrd_assym apply blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   209
using PosOrd_trans by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   210
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   211
lemma PosOrd_order:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   212
  shows "class.order (\<lambda>v1 v2. v1 :\<sqsubseteq>val v2) (\<lambda> v1 v2. v1 :\<sqsubset>val v2)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   213
using PosOrd_ordering
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   214
apply(simp add: class.order_def class.preorder_def class.order_axioms_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   215
unfolding ordering_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   216
by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   217
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   218
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   219
lemma PosOrd_ex_eq2:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   220
  shows "v1 :\<sqsubset>val v2 \<longleftrightarrow> (v1 :\<sqsubseteq>val v2 \<and> v1 \<noteq> v2)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   221
using PosOrd_ordering 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   222
unfolding ordering_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   223
by auto
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   224
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   225
lemma PosOrdeq_trans:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   226
  assumes "v1 :\<sqsubseteq>val v2" "v2 :\<sqsubseteq>val v3"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   227
  shows "v1 :\<sqsubseteq>val v3"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   228
using assms PosOrd_ordering 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   229
unfolding ordering_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   230
by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   231
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   232
lemma PosOrdeq_antisym:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   233
  assumes "v1 :\<sqsubseteq>val v2" "v2 :\<sqsubseteq>val v1"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   234
  shows "v1 = v2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   235
using assms PosOrd_ordering 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   236
unfolding ordering_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   237
by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   238
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   239
lemma PosOrdeq_refl:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   240
  shows "v :\<sqsubseteq>val v" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   241
unfolding PosOrd_ex_eq_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   242
by auto
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   243
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   244
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   245
lemma PosOrd_shorterE:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   246
  assumes "v1 :\<sqsubset>val v2" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   247
  shows "length (flat v2) \<le> length (flat v1)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   248
using assms unfolding PosOrd_ex_def PosOrd_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   249
apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   250
apply(case_tac p)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   251
apply(simp add: pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   252
apply(drule_tac x="[]" in bspec)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   253
apply(simp add: Pos_empty)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   254
apply(simp add: pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   255
done
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   256
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   257
lemma PosOrd_shorterI:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   258
  assumes "length (flat v2) < length (flat v1)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   259
  shows "v1 :\<sqsubset>val v2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   260
unfolding PosOrd_ex_def PosOrd_def pflat_len_def 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   261
using assms Pos_empty by force
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   262
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   263
lemma PosOrd_spreI:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   264
  assumes "flat v' \<sqsubset>spre flat v"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   265
  shows "v :\<sqsubset>val v'" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   266
using assms
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   267
apply(rule_tac PosOrd_shorterI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   268
unfolding prefix_list_def sprefix_list_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   269
by (metis append_Nil2 append_eq_conv_conj drop_all le_less_linear)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   270
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   271
lemma pflat_len_inside:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   272
  assumes "pflat_len v2 p < pflat_len v1 p"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   273
  shows "p \<in> Pos v1"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   274
using assms 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   275
unfolding pflat_len_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   276
by (auto split: if_splits)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   277
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   278
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   279
lemma PosOrd_Left_Right:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   280
  assumes "flat v1 = flat v2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   281
  shows "Left v1 :\<sqsubset>val Right v2" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   282
unfolding PosOrd_ex_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   283
apply(rule_tac x="[0]" in exI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   284
apply(auto simp add: PosOrd_def pflat_len_simps assms)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   285
done
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   286
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   287
lemma PosOrd_LeftE:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   288
  assumes "Left v1 :\<sqsubset>val Left v2" "flat v1 = flat v2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   289
  shows "v1 :\<sqsubset>val v2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   290
using assms
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   291
unfolding PosOrd_ex_def PosOrd_def2
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   292
apply(auto simp add: pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   293
apply(frule pflat_len_inside)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   294
apply(auto simp add: pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   295
by (metis lex_simps(3) pflat_len_simps(3))
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   296
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   297
lemma PosOrd_LeftI:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   298
  assumes "v1 :\<sqsubset>val v2" "flat v1 = flat v2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   299
  shows  "Left v1 :\<sqsubset>val Left v2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   300
using assms
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   301
unfolding PosOrd_ex_def PosOrd_def2
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   302
apply(auto simp add: pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   303
by (metis less_numeral_extra(3) lex_simps(3) pflat_len_simps(3))
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   304
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   305
lemma PosOrd_Left_eq:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   306
  assumes "flat v1 = flat v2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   307
  shows "Left v1 :\<sqsubset>val Left v2 \<longleftrightarrow> v1 :\<sqsubset>val v2" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   308
using assms PosOrd_LeftE PosOrd_LeftI
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   309
by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   310
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   311
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   312
lemma PosOrd_RightE:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   313
  assumes "Right v1 :\<sqsubset>val Right v2" "flat v1 = flat v2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   314
  shows "v1 :\<sqsubset>val v2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   315
using assms
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   316
unfolding PosOrd_ex_def PosOrd_def2
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   317
apply(auto simp add: pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   318
apply(frule pflat_len_inside)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   319
apply(auto simp add: pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   320
by (metis lex_simps(3) pflat_len_simps(5))
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   321
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   322
lemma PosOrd_RightI:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   323
  assumes "v1 :\<sqsubset>val v2" "flat v1 = flat v2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   324
  shows  "Right v1 :\<sqsubset>val Right v2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   325
using assms
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   326
unfolding PosOrd_ex_def PosOrd_def2
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   327
apply(auto simp add: pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   328
by (metis lex_simps(3) nat_neq_iff pflat_len_simps(5))
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   329
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   330
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   331
lemma PosOrd_Right_eq:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   332
  assumes "flat v1 = flat v2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   333
  shows "Right v1 :\<sqsubset>val Right v2 \<longleftrightarrow> v1 :\<sqsubset>val v2" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   334
using assms PosOrd_RightE PosOrd_RightI
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   335
by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   336
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   337
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   338
lemma PosOrd_SeqI1:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   339
  assumes "v1 :\<sqsubset>val w1" "flat (Seq v1 v2) = flat (Seq w1 w2)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   340
  shows "Seq v1 v2 :\<sqsubset>val Seq w1 w2" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   341
using assms(1)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   342
apply(subst (asm) PosOrd_ex_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   343
apply(subst (asm) PosOrd_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   344
apply(clarify)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   345
apply(subst PosOrd_ex_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   346
apply(rule_tac x="0#p" in exI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   347
apply(subst PosOrd_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   348
apply(rule conjI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   349
apply(simp add: pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   350
apply(rule ballI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   351
apply(rule impI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   352
apply(simp only: Pos.simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   353
apply(auto)[1]
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   354
apply(simp add: pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   355
apply(auto simp add: pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   356
using assms(2)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   357
apply(simp)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   358
apply(metis length_append of_nat_add)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   359
done
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   360
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   361
lemma PosOrd_SeqI2:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   362
  assumes "v2 :\<sqsubset>val w2" "flat v2 = flat w2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   363
  shows "Seq v v2 :\<sqsubset>val Seq v w2" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   364
using assms(1)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   365
apply(subst (asm) PosOrd_ex_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   366
apply(subst (asm) PosOrd_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   367
apply(clarify)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   368
apply(subst PosOrd_ex_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   369
apply(rule_tac x="Suc 0#p" in exI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   370
apply(subst PosOrd_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   371
apply(rule conjI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   372
apply(simp add: pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   373
apply(rule ballI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   374
apply(rule impI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   375
apply(simp only: Pos.simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   376
apply(auto)[1]
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   377
apply(simp add: pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   378
using assms(2)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   379
apply(simp)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   380
apply(auto simp add: pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   381
done
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   382
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   383
lemma PosOrd_Seq_eq:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   384
  assumes "flat v2 = flat w2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   385
  shows "(Seq v v2) :\<sqsubset>val (Seq v w2) \<longleftrightarrow> v2 :\<sqsubset>val w2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   386
using assms 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   387
apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   388
prefer 2
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   389
apply(simp add: PosOrd_SeqI2)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   390
apply(simp add: PosOrd_ex_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   391
apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   392
apply(case_tac p)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   393
apply(simp add: PosOrd_def pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   394
apply(case_tac a)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   395
apply(simp add: PosOrd_def pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   396
apply(clarify)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   397
apply(case_tac nat)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   398
prefer 2
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   399
apply(simp add: PosOrd_def pflat_len_simps pflat_len_outside)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   400
apply(rule_tac x="list" in exI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   401
apply(auto simp add: PosOrd_def2 pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   402
apply(smt Collect_disj_eq lex_list.intros(2) mem_Collect_eq pflat_len_simps(2))
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   403
apply(smt Collect_disj_eq lex_list.intros(2) mem_Collect_eq pflat_len_simps(2))
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   404
done
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   405
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   406
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   407
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   408
lemma PosOrd_StarsI:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   409
  assumes "v1 :\<sqsubset>val v2" "flats (v1#vs1) = flats (v2#vs2)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   410
  shows "Stars (v1#vs1) :\<sqsubset>val Stars (v2#vs2)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   411
using assms(1)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   412
apply(subst (asm) PosOrd_ex_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   413
apply(subst (asm) PosOrd_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   414
apply(clarify)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   415
apply(subst PosOrd_ex_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   416
apply(subst PosOrd_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   417
apply(rule_tac x="0#p" in exI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   418
apply(simp add: pflat_len_Stars_simps pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   419
using assms(2)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   420
apply(simp add: pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   421
apply(auto simp add: pflat_len_Stars_simps pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   422
by (metis length_append of_nat_add)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   423
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   424
lemma PosOrd_StarsI2:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   425
  assumes "Stars vs1 :\<sqsubset>val Stars vs2" "flats vs1 = flats vs2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   426
  shows "Stars (v#vs1) :\<sqsubset>val Stars (v#vs2)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   427
using assms(1)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   428
apply(subst (asm) PosOrd_ex_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   429
apply(subst (asm) PosOrd_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   430
apply(clarify)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   431
apply(subst PosOrd_ex_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   432
apply(subst PosOrd_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   433
apply(case_tac p)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   434
apply(simp add: pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   435
apply(rule_tac x="Suc a#list" in exI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   436
apply(auto simp add: pflat_len_Stars_simps pflat_len_simps assms(2))
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   437
done
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   438
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   439
lemma PosOrd_Stars_appendI:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   440
  assumes "Stars vs1 :\<sqsubset>val Stars vs2" "flat (Stars vs1) = flat (Stars vs2)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   441
  shows "Stars (vs @ vs1) :\<sqsubset>val Stars (vs @ vs2)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   442
using assms
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   443
apply(induct vs)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   444
apply(simp)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   445
apply(simp add: PosOrd_StarsI2)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   446
done
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   447
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   448
lemma PosOrd_eq_Stars_zipI:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   449
  assumes "\<forall>(v1, v2) \<in> set (zip vs1 vs2). v1 :\<sqsubseteq>val v2" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   450
     "length vs1 = length vs2" "flats vs1 = flats vs2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   451
  shows "Stars vs1 :\<sqsubseteq>val Stars vs2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   452
  using assms
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   453
  apply(induct vs1 arbitrary: vs2)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   454
   apply(case_tac vs2)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   455
apply(simp add: PosOrd_ex_eq_def)    
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   456
   apply(simp)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   457
  apply(case_tac vs2)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   458
   apply(simp)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   459
  apply(simp)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   460
  apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   461
apply(subst (asm) (2)PosOrd_ex_eq_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   462
  apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   463
   apply(subst PosOrd_ex_eq_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   464
   apply(rule disjI1)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   465
   apply(rule PosOrd_StarsI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   466
    apply(simp)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   467
   apply(simp)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   468
  using PosOrd_StarsI2 PosOrd_ex_eq_def by fastforce
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   469
  
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   470
lemma PosOrd_StarsE2:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   471
  assumes "Stars (v # vs1) :\<sqsubset>val Stars (v # vs2)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   472
  shows "Stars vs1 :\<sqsubset>val Stars vs2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   473
using assms
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   474
apply(subst (asm) PosOrd_ex_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   475
apply(erule exE)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   476
apply(case_tac p)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   477
apply(simp)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   478
apply(simp add: PosOrd_def pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   479
apply(subst PosOrd_ex_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   480
apply(rule_tac x="[]" in exI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   481
apply(simp add: PosOrd_def pflat_len_simps Pos_empty)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   482
apply(simp)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   483
apply(case_tac a)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   484
apply(clarify)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   485
apply(auto simp add: pflat_len_simps PosOrd_def pflat_len_def split: if_splits)[1]
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   486
apply(clarify)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   487
apply(simp add: PosOrd_ex_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   488
apply(rule_tac x="nat#list" in exI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   489
apply(auto simp add: PosOrd_def pflat_len_simps)[1]
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   490
apply(case_tac q)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   491
apply(simp add: PosOrd_def pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   492
apply(clarify)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   493
apply(drule_tac x="Suc a # lista" in bspec)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   494
apply(simp)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   495
apply(auto simp add: PosOrd_def pflat_len_simps)[1]
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   496
apply(case_tac q)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   497
apply(simp add: PosOrd_def pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   498
apply(clarify)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   499
apply(drule_tac x="Suc a # lista" in bspec)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   500
apply(simp)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   501
apply(auto simp add: PosOrd_def pflat_len_simps)[1]
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   502
done
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   503
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   504
lemma PosOrd_Stars_appendE:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   505
  assumes "Stars (vs @ vs1) :\<sqsubset>val Stars (vs @ vs2)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   506
  shows "Stars vs1 :\<sqsubset>val Stars vs2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   507
using assms
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   508
apply(induct vs)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   509
apply(simp)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   510
apply(simp add: PosOrd_StarsE2)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   511
done
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   512
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   513
lemma PosOrd_Stars_append_eq:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   514
  assumes "flats vs1 = flats vs2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   515
  shows "Stars (vs @ vs1) :\<sqsubset>val Stars (vs @ vs2) \<longleftrightarrow> Stars vs1 :\<sqsubset>val Stars vs2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   516
using assms
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   517
apply(rule_tac iffI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   518
apply(erule PosOrd_Stars_appendE)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   519
apply(rule PosOrd_Stars_appendI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   520
apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   521
done  
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   522
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   523
lemma PosOrd_almost_trichotomous:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   524
  shows "v1 :\<sqsubset>val v2 \<or> v2 :\<sqsubset>val v1 \<or> (length (flat v1) = length (flat v2))"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   525
apply(auto simp add: PosOrd_ex_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   526
apply(auto simp add: PosOrd_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   527
apply(rule_tac x="[]" in exI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   528
apply(auto simp add: Pos_empty pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   529
apply(drule_tac x="[]" in spec)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   530
apply(auto simp add: Pos_empty pflat_len_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   531
done
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   532
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   533
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   534
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   535
section {* The Posix Value is smaller than any other Value *}
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   536
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   537
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   538
lemma Posix_PosOrd:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   539
  assumes "s \<in> r \<rightarrow> v1" "v2 \<in> LV r s" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   540
  shows "v1 :\<sqsubseteq>val v2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   541
using assms
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   542
proof (induct arbitrary: v2 rule: Posix.induct)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   543
  case (Posix_ONE v)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   544
  have "v \<in> LV ONE []" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   545
  then have "v = Void"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   546
    by (simp add: LV_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   547
  then show "Void :\<sqsubseteq>val v"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   548
    by (simp add: PosOrd_ex_eq_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   549
next
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   550
  case (Posix_CHAR c v)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   551
  have "v \<in> LV (CHAR c) [c]" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   552
  then have "v = Char c"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   553
    by (simp add: LV_simps)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   554
  then show "Char c :\<sqsubseteq>val v"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   555
    by (simp add: PosOrd_ex_eq_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   556
next
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   557
  case (Posix_ALT1 s r1 v r2 v2)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   558
  have as1: "s \<in> r1 \<rightarrow> v" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   559
  have IH: "\<And>v2. v2 \<in> LV r1 s \<Longrightarrow> v :\<sqsubseteq>val v2" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   560
  have "v2 \<in> LV (ALT r1 r2) s" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   561
  then have "\<Turnstile> v2 : ALT r1 r2" "flat v2 = s"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   562
    by(auto simp add: LV_def prefix_list_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   563
  then consider
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   564
    (Left) v3 where "v2 = Left v3" "\<Turnstile> v3 : r1" "flat v3 = s" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   565
  | (Right) v3 where "v2 = Right v3" "\<Turnstile> v3 : r2" "flat v3 = s"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   566
  by (auto elim: Prf.cases)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   567
  then show "Left v :\<sqsubseteq>val v2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   568
  proof(cases)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   569
     case (Left v3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   570
     have "v3 \<in> LV r1 s" using Left(2,3) 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   571
       by (auto simp add: LV_def prefix_list_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   572
     with IH have "v :\<sqsubseteq>val v3" by simp
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   573
     moreover
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   574
     have "flat v3 = flat v" using as1 Left(3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   575
       by (simp add: Posix1(2)) 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   576
     ultimately have "Left v :\<sqsubseteq>val Left v3"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   577
       by (simp add: PosOrd_ex_eq_def PosOrd_Left_eq)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   578
     then show "Left v :\<sqsubseteq>val v2" unfolding Left .
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   579
  next
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   580
     case (Right v3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   581
     have "flat v3 = flat v" using as1 Right(3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   582
       by (simp add: Posix1(2)) 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   583
     then have "Left v :\<sqsubseteq>val Right v3" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   584
       unfolding PosOrd_ex_eq_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   585
       by (simp add: PosOrd_Left_Right)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   586
     then show "Left v :\<sqsubseteq>val v2" unfolding Right .
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   587
  qed
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   588
next
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   589
  case (Posix_ALT2 s r2 v r1 v2)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   590
  have as1: "s \<in> r2 \<rightarrow> v" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   591
  have as2: "s \<notin> L r1" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   592
  have IH: "\<And>v2. v2 \<in> LV r2 s \<Longrightarrow> v :\<sqsubseteq>val v2" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   593
  have "v2 \<in> LV (ALT r1 r2) s" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   594
  then have "\<Turnstile> v2 : ALT r1 r2" "flat v2 = s"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   595
    by(auto simp add: LV_def prefix_list_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   596
  then consider
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   597
    (Left) v3 where "v2 = Left v3" "\<Turnstile> v3 : r1" "flat v3 = s" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   598
  | (Right) v3 where "v2 = Right v3" "\<Turnstile> v3 : r2" "flat v3 = s"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   599
  by (auto elim: Prf.cases)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   600
  then show "Right v :\<sqsubseteq>val v2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   601
  proof (cases)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   602
    case (Right v3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   603
     have "v3 \<in> LV r2 s" using Right(2,3) 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   604
       by (auto simp add: LV_def prefix_list_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   605
     with IH have "v :\<sqsubseteq>val v3" by simp
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   606
     moreover
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   607
     have "flat v3 = flat v" using as1 Right(3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   608
       by (simp add: Posix1(2)) 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   609
     ultimately have "Right v :\<sqsubseteq>val Right v3" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   610
        by (auto simp add: PosOrd_ex_eq_def PosOrd_RightI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   611
     then show "Right v :\<sqsubseteq>val v2" unfolding Right .
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   612
  next
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   613
     case (Left v3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   614
     have "v3 \<in> LV r1 s" using Left(2,3) as2  
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   615
       by (auto simp add: LV_def prefix_list_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   616
     then have "flat v3 = flat v \<and> \<Turnstile> v3 : r1" using as1 Left(3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   617
       by (simp add: Posix1(2) LV_def) 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   618
     then have "False" using as1 as2 Left
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   619
       by (auto simp add: Posix1(2) L_flat_Prf1)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   620
     then show "Right v :\<sqsubseteq>val v2" by simp
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   621
  qed
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   622
next 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   623
  case (Posix_SEQ s1 r1 v1 s2 r2 v2 v3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   624
  have "s1 \<in> r1 \<rightarrow> v1" "s2 \<in> r2 \<rightarrow> v2" by fact+
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   625
  then have as1: "s1 = flat v1" "s2 = flat v2" by (simp_all add: Posix1(2))
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   626
  have IH1: "\<And>v3. v3 \<in> LV r1 s1 \<Longrightarrow> v1 :\<sqsubseteq>val v3" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   627
  have IH2: "\<And>v3. v3 \<in> LV r2 s2 \<Longrightarrow> v2 :\<sqsubseteq>val v3" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   628
  have cond: "\<not> (\<exists>s\<^sub>3 s\<^sub>4. s\<^sub>3 \<noteq> [] \<and> s\<^sub>3 @ s\<^sub>4 = s2 \<and> s1 @ s\<^sub>3 \<in> L r1 \<and> s\<^sub>4 \<in> L r2)" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   629
  have "v3 \<in> LV (SEQ r1 r2) (s1 @ s2)" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   630
  then obtain v3a v3b where eqs:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   631
    "v3 = Seq v3a v3b" "\<Turnstile> v3a : r1" "\<Turnstile> v3b : r2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   632
    "flat v3a @ flat v3b = s1 @ s2" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   633
    by (force simp add: prefix_list_def LV_def elim: Prf.cases)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   634
  with cond have "flat v3a \<sqsubseteq>pre s1" unfolding prefix_list_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   635
    by (smt L_flat_Prf1 append_eq_append_conv2 append_self_conv)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   636
  then have "flat v3a \<sqsubset>spre s1 \<or> (flat v3a = s1 \<and> flat v3b = s2)" using eqs
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   637
    by (simp add: sprefix_list_def append_eq_conv_conj)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   638
  then have q2: "v1 :\<sqsubset>val v3a \<or> (flat v3a = s1 \<and> flat v3b = s2)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   639
    using PosOrd_spreI as1(1) eqs by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   640
  then have "v1 :\<sqsubset>val v3a \<or> (v3a \<in> LV r1 s1 \<and> v3b \<in> LV r2 s2)" using eqs(2,3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   641
    by (auto simp add: LV_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   642
  then have "v1 :\<sqsubset>val v3a \<or> (v1 :\<sqsubseteq>val v3a \<and> v2 :\<sqsubseteq>val v3b)" using IH1 IH2 by blast         
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   643
  then have "Seq v1 v2 :\<sqsubseteq>val Seq v3a v3b" using eqs q2 as1
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   644
    unfolding  PosOrd_ex_eq_def by (auto simp add: PosOrd_SeqI1 PosOrd_Seq_eq) 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   645
  then show "Seq v1 v2 :\<sqsubseteq>val v3" unfolding eqs by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   646
next 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   647
  case (Posix_STAR1 s1 r v s2 vs v3) 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   648
  have "s1 \<in> r \<rightarrow> v" "s2 \<in> STAR r \<rightarrow> Stars vs" by fact+
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   649
  then have as1: "s1 = flat v" "s2 = flat (Stars vs)" by (auto dest: Posix1(2))
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   650
  have IH1: "\<And>v3. v3 \<in> LV r s1 \<Longrightarrow> v :\<sqsubseteq>val v3" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   651
  have IH2: "\<And>v3. v3 \<in> LV (STAR r) s2 \<Longrightarrow> Stars vs :\<sqsubseteq>val v3" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   652
  have cond: "\<not> (\<exists>s\<^sub>3 s\<^sub>4. s\<^sub>3 \<noteq> [] \<and> s\<^sub>3 @ s\<^sub>4 = s2 \<and> s1 @ s\<^sub>3 \<in> L r \<and> s\<^sub>4 \<in> L (STAR r))" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   653
  have cond2: "flat v \<noteq> []" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   654
  have "v3 \<in> LV (STAR r) (s1 @ s2)" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   655
  then consider 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   656
    (NonEmpty) v3a vs3 where "v3 = Stars (v3a # vs3)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   657
    "\<Turnstile> v3a : r" "\<Turnstile> Stars vs3 : STAR r"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   658
    "flat (Stars (v3a # vs3)) = s1 @ s2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   659
  | (Empty) "v3 = Stars []"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   660
  unfolding LV_def  
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   661
  apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   662
  apply(erule Prf.cases)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   663
  apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   664
  apply(case_tac vs)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   665
  apply(auto intro: Prf.intros)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   666
  done
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   667
  then show "Stars (v # vs) :\<sqsubseteq>val v3" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   668
    proof (cases)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   669
      case (NonEmpty v3a vs3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   670
      have "flat (Stars (v3a # vs3)) = s1 @ s2" using NonEmpty(4) . 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   671
      with cond have "flat v3a \<sqsubseteq>pre s1" using NonEmpty(2,3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   672
        unfolding prefix_list_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   673
        by (smt L_flat_Prf1 append_Nil2 append_eq_append_conv2 flat.simps(7)) 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   674
      then have "flat v3a \<sqsubset>spre s1 \<or> (flat v3a = s1 \<and> flat (Stars vs3) = s2)" using NonEmpty(4)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   675
        by (simp add: sprefix_list_def append_eq_conv_conj)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   676
      then have q2: "v :\<sqsubset>val v3a \<or> (flat v3a = s1 \<and> flat (Stars vs3) = s2)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   677
        using PosOrd_spreI as1(1) NonEmpty(4) by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   678
      then have "v :\<sqsubset>val v3a \<or> (v3a \<in> LV r s1 \<and> Stars vs3 \<in> LV (STAR r) s2)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   679
        using NonEmpty(2,3) by (auto simp add: LV_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   680
      then have "v :\<sqsubset>val v3a \<or> (v :\<sqsubseteq>val v3a \<and> Stars vs :\<sqsubseteq>val Stars vs3)" using IH1 IH2 by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   681
      then have "v :\<sqsubset>val v3a \<or> (v = v3a \<and> Stars vs :\<sqsubseteq>val Stars vs3)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   682
         unfolding PosOrd_ex_eq_def by auto     
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   683
      then have "Stars (v # vs) :\<sqsubseteq>val Stars (v3a # vs3)" using NonEmpty(4) q2 as1
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   684
        unfolding  PosOrd_ex_eq_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   685
        using PosOrd_StarsI PosOrd_StarsI2 by auto 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   686
      then show "Stars (v # vs) :\<sqsubseteq>val v3" unfolding NonEmpty by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   687
    next 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   688
      case Empty
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   689
      have "v3 = Stars []" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   690
      then show "Stars (v # vs) :\<sqsubseteq>val v3"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   691
      unfolding PosOrd_ex_eq_def using cond2
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   692
      by (simp add: PosOrd_shorterI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   693
    qed      
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   694
next 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   695
  case (Posix_STAR2 r v2)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   696
  have "v2 \<in> LV (STAR r) []" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   697
  then have "v2 = Stars []" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   698
    unfolding LV_def by (auto elim: Prf.cases) 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   699
  then show "Stars [] :\<sqsubseteq>val v2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   700
    by (simp add: PosOrd_ex_eq_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   701
next 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   702
  case (Posix_NTIMES1 s1 r v s2 n vs v3) 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   703
  have "s1 \<in> r \<rightarrow> v" "s2 \<in> NTIMES r (n - 1) \<rightarrow> Stars vs" by fact+
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   704
  then have as1: "s1 = flat v" "s2 = flats vs" by (auto dest: Posix1(2))
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   705
  have IH1: "\<And>v3. v3 \<in> LV r s1 \<Longrightarrow> v :\<sqsubseteq>val v3" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   706
  have IH2: "\<And>v3. v3 \<in> LV (NTIMES r (n - 1)) s2 \<Longrightarrow> Stars vs :\<sqsubseteq>val v3" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   707
  have cond: "\<not> (\<exists>s\<^sub>3 s\<^sub>4. s\<^sub>3 \<noteq> [] \<and> s\<^sub>3 @ s\<^sub>4 = s2 \<and> s1 @ s\<^sub>3 \<in> L r \<and> s\<^sub>4 \<in> L (NTIMES r (n - 1)))" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   708
  have cond2: "flat v \<noteq> []" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   709
  have "v3 \<in> LV (NTIMES r n) (s1 @ s2)" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   710
  then consider 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   711
    (NonEmpty) v3a vs3 where "v3 = Stars (v3a # vs3)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   712
    "\<Turnstile> v3a : r" "\<Turnstile> Stars vs3 : NTIMES r (n - 1)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   713
    "flats (v3a # vs3) = s1 @ s2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   714
  | (Empty) "v3 = Stars []"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   715
  unfolding LV_def  
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   716
  apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   717
  apply(erule Prf.cases)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   718
             apply(auto)  
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   719
  apply(case_tac vs1)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   720
   apply(auto intro: Prf.intros)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   721
   apply(case_tac vs2)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   722
    apply(auto intro: Prf.intros)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   723
  apply (simp add: as1(1) cond2 flats_empty)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   724
  by (simp add: Prf.intros(8))
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   725
  then show "Stars (v # vs) :\<sqsubseteq>val v3" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   726
    proof (cases)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   727
      case (NonEmpty v3a vs3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   728
      have "flats (v3a # vs3) = s1 @ s2" using NonEmpty(4) . 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   729
      with cond have "flat v3a \<sqsubseteq>pre s1" using NonEmpty(2,3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   730
        unfolding prefix_list_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   731
        by (smt L_flat_Prf1 append_Nil2 append_eq_append_conv2 flat.simps(7) flat_Stars)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   732
      then have "flat v3a \<sqsubset>spre s1 \<or> (flat v3a = s1 \<and> flat (Stars vs3) = s2)" using NonEmpty(4)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   733
        by (simp add: sprefix_list_def append_eq_conv_conj)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   734
      then have q2: "v :\<sqsubset>val v3a \<or> (flat v3a = s1 \<and> flat (Stars vs3) = s2)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   735
        using PosOrd_spreI as1(1) NonEmpty(4) by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   736
      then have "v :\<sqsubset>val v3a \<or> (v3a \<in> LV r s1 \<and> Stars vs3 \<in> LV (NTIMES r (n - 1)) s2)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   737
        using NonEmpty(2,3) by (auto simp add: LV_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   738
      then have "v :\<sqsubset>val v3a \<or> (v :\<sqsubseteq>val v3a \<and> Stars vs :\<sqsubseteq>val Stars vs3)" using IH1 IH2 by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   739
      then have "v :\<sqsubset>val v3a \<or> (v = v3a \<and> Stars vs :\<sqsubseteq>val Stars vs3)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   740
         unfolding PosOrd_ex_eq_def by auto     
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   741
      then have "Stars (v # vs) :\<sqsubseteq>val Stars (v3a # vs3)" using NonEmpty(4) q2 as1
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   742
        unfolding  PosOrd_ex_eq_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   743
        using PosOrd_StarsI PosOrd_StarsI2 by auto 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   744
      then show "Stars (v # vs) :\<sqsubseteq>val v3" unfolding NonEmpty by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   745
    next 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   746
      case Empty
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   747
      have "v3 = Stars []" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   748
      then show "Stars (v # vs) :\<sqsubseteq>val v3"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   749
      unfolding PosOrd_ex_eq_def using cond2
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   750
      by (simp add: PosOrd_shorterI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   751
  qed 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   752
next
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   753
  case (Posix_NTIMES2 vs r n v2) 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   754
  then show "Stars vs :\<sqsubseteq>val v2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   755
    apply(simp add: LV_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   756
    apply(auto)  
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   757
    apply(erule Prf_elims)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   758
    apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   759
    apply(rule PosOrd_eq_Stars_zipI) 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   760
      prefer 2
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   761
      apply(simp)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   762
     prefer 2
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   763
     apply (metis Posix1(2) flats_empty)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   764
    apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   765
    by (meson in_set_zipE)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   766
next
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   767
  case (Posix_UPNTIMES2 r n v2)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   768
    then show "Stars [] :\<sqsubseteq>val v2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   769
    apply(simp add: LV_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   770
      apply(auto)  
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   771
    apply(erule Prf_elims)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   772
      apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   773
      unfolding PosOrd_ex_eq_def by simp
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   774
next 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   775
  case (Posix_UPNTIMES1 s1 r v s2 n vs v3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   776
  have "s1 \<in> r \<rightarrow> v" "s2 \<in> UPNTIMES r (n - 1) \<rightarrow> Stars vs" by fact+
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   777
  then have as1: "s1 = flat v" "s2 = flat (Stars vs)" by (auto dest: Posix1(2))
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   778
  have IH1: "\<And>v3. v3 \<in> LV r s1 \<Longrightarrow> v :\<sqsubseteq>val v3" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   779
  have IH2: "\<And>v3. v3 \<in> LV (UPNTIMES r (n - 1)) s2 \<Longrightarrow> Stars vs :\<sqsubseteq>val v3" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   780
  have cond: "\<not> (\<exists>s\<^sub>3 s\<^sub>4. s\<^sub>3 \<noteq> [] \<and> s\<^sub>3 @ s\<^sub>4 = s2 \<and> s1 @ s\<^sub>3 \<in> L r \<and> s\<^sub>4 \<in> L (UPNTIMES r (n - 1)))" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   781
  have cond2: "flat v \<noteq> []" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   782
  have "v3 \<in> LV (UPNTIMES r n) (s1 @ s2)" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   783
  then consider 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   784
    (NonEmpty) v3a vs3 where "v3 = Stars (v3a # vs3)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   785
    "\<Turnstile> v3a : r" "\<Turnstile> Stars vs3 : UPNTIMES r (n - 1)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   786
    "flats (v3a # vs3) = s1 @ s2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   787
  | (Empty) "v3 = Stars []"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   788
  unfolding LV_def  
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   789
  apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   790
  apply(erule Prf.cases)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   791
  apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   792
  apply(case_tac vs)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   793
   apply(auto intro: Prf.intros)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   794
  by (simp add: Prf.intros(7) as1(1) cond2)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   795
  then show "Stars (v # vs) :\<sqsubseteq>val v3" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   796
    proof (cases)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   797
      case (NonEmpty v3a vs3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   798
      have "flats (v3a # vs3) = s1 @ s2" using NonEmpty(4) . 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   799
      with cond have "flat v3a \<sqsubseteq>pre s1" using NonEmpty(2,3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   800
        unfolding prefix_list_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   801
        apply(simp)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   802
        apply(simp add: append_eq_append_conv2)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   803
        apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   804
        by (metis L_flat_Prf1 One_nat_def cond flat_Stars)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   805
      then have "flat v3a \<sqsubset>spre s1 \<or> (flat v3a = s1 \<and> flat (Stars vs3) = s2)" using NonEmpty(4)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   806
        by (simp add: sprefix_list_def append_eq_conv_conj)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   807
      then have q2: "v :\<sqsubset>val v3a \<or> (flat v3a = s1 \<and> flat (Stars vs3) = s2)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   808
        using PosOrd_spreI as1(1) NonEmpty(4) by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   809
      then have "v :\<sqsubset>val v3a \<or> (v3a \<in> LV r s1 \<and> Stars vs3 \<in> LV (UPNTIMES r (n - 1)) s2)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   810
        using NonEmpty(2,3) by (auto simp add: LV_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   811
      then have "v :\<sqsubset>val v3a \<or> (v :\<sqsubseteq>val v3a \<and> Stars vs :\<sqsubseteq>val Stars vs3)" using IH1 IH2 by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   812
      then have "v :\<sqsubset>val v3a \<or> (v = v3a \<and> Stars vs :\<sqsubseteq>val Stars vs3)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   813
         unfolding PosOrd_ex_eq_def by auto     
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   814
      then have "Stars (v # vs) :\<sqsubseteq>val Stars (v3a # vs3)" using NonEmpty(4) q2 as1
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   815
        unfolding  PosOrd_ex_eq_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   816
        using PosOrd_StarsI PosOrd_StarsI2 by auto 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   817
      then show "Stars (v # vs) :\<sqsubseteq>val v3" unfolding NonEmpty by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   818
    next 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   819
      case Empty
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   820
      have "v3 = Stars []" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   821
      then show "Stars (v # vs) :\<sqsubseteq>val v3"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   822
      unfolding PosOrd_ex_eq_def using cond2
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   823
      by (simp add: PosOrd_shorterI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   824
  qed        
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   825
next
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   826
  case (Posix_FROMNTIMES2 vs r n v2)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   827
    then show "Stars vs :\<sqsubseteq>val v2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   828
    apply(simp add: LV_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   829
      apply(auto)  
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   830
    apply(erule Prf_elims)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   831
       apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   832
        apply(rule PosOrd_eq_Stars_zipI) 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   833
      prefer 2
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   834
      apply(simp)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   835
     prefer 2
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   836
     apply (metis Posix1(2) flats_empty)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   837
    apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   838
      by (meson in_set_zipE)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   839
next 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   840
  case (Posix_FROMNTIMES1 s1 r v s2 n vs v3) 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   841
  have "s1 \<in> r \<rightarrow> v" "s2 \<in> FROMNTIMES r (n - 1) \<rightarrow> Stars vs" by fact+
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   842
  then have as1: "s1 = flat v" "s2 = flats vs" by (auto dest: Posix1(2))
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   843
  have IH1: "\<And>v3. v3 \<in> LV r s1 \<Longrightarrow> v :\<sqsubseteq>val v3" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   844
  have IH2: "\<And>v3. v3 \<in> LV (FROMNTIMES r (n - 1)) s2 \<Longrightarrow> Stars vs :\<sqsubseteq>val v3" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   845
  have cond: "\<not> (\<exists>s\<^sub>3 s\<^sub>4. s\<^sub>3 \<noteq> [] \<and> s\<^sub>3 @ s\<^sub>4 = s2 \<and> s1 @ s\<^sub>3 \<in> L r \<and> s\<^sub>4 \<in> L (FROMNTIMES r (n - 1)))" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   846
  have cond2: "flat v \<noteq> []" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   847
  have "v3 \<in> LV (FROMNTIMES r n) (s1 @ s2)" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   848
  then consider 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   849
    (NonEmpty) v3a vs3 where "v3 = Stars (v3a # vs3)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   850
    "\<Turnstile> v3a : r" "\<Turnstile> Stars vs3 : FROMNTIMES r (n - 1)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   851
    "flats (v3a # vs3) = s1 @ s2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   852
  | (Empty) "v3 = Stars []" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   853
  unfolding LV_def  
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   854
  apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   855
  apply(erule Prf.cases)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   856
             apply(auto)  
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   857
  apply(case_tac vs1)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   858
   apply(auto intro: Prf.intros)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   859
   apply(case_tac vs2)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   860
    apply(auto intro: Prf.intros)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   861
    apply (simp add: as1(1) cond2 flats_empty)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   862
  apply (simp add: Prf.intros)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   863
  apply(case_tac vs)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   864
   apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   865
  using Posix_FROMNTIMES1.hyps(6) Prf.intros(10) by auto
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   866
  then show "Stars (v # vs) :\<sqsubseteq>val v3" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   867
    proof (cases)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   868
      case (NonEmpty v3a vs3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   869
      have "flats (v3a # vs3) = s1 @ s2" using NonEmpty(4) . 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   870
      with cond have "flat v3a \<sqsubseteq>pre s1" using NonEmpty(2,3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   871
        unfolding prefix_list_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   872
        by (smt L_flat_Prf1 append_Nil2 append_eq_append_conv2 flat.simps(7) flat_Stars)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   873
      then have "flat v3a \<sqsubset>spre s1 \<or> (flat v3a = s1 \<and> flat (Stars vs3) = s2)" using NonEmpty(4)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   874
        by (simp add: sprefix_list_def append_eq_conv_conj)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   875
      then have q2: "v :\<sqsubset>val v3a \<or> (flat v3a = s1 \<and> flat (Stars vs3) = s2)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   876
        using PosOrd_spreI as1(1) NonEmpty(4) by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   877
      then have "v :\<sqsubset>val v3a \<or> (v3a \<in> LV r s1 \<and> Stars vs3 \<in> LV (FROMNTIMES r (n - 1)) s2)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   878
        using NonEmpty(2,3) by (auto simp add: LV_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   879
      then have "v :\<sqsubset>val v3a \<or> (v :\<sqsubseteq>val v3a \<and> Stars vs :\<sqsubseteq>val Stars vs3)" using IH1 IH2 by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   880
      then have "v :\<sqsubset>val v3a \<or> (v = v3a \<and> Stars vs :\<sqsubseteq>val Stars vs3)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   881
         unfolding PosOrd_ex_eq_def by auto     
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   882
      then have "Stars (v # vs) :\<sqsubseteq>val Stars (v3a # vs3)" using NonEmpty(4) q2 as1
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   883
        unfolding  PosOrd_ex_eq_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   884
        using PosOrd_StarsI PosOrd_StarsI2 by auto 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   885
      then show "Stars (v # vs) :\<sqsubseteq>val v3" unfolding NonEmpty by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   886
    next 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   887
      case Empty
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   888
      have "v3 = Stars []" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   889
      then show "Stars (v # vs) :\<sqsubseteq>val v3"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   890
      unfolding PosOrd_ex_eq_def using cond2
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   891
      by (simp add: PosOrd_shorterI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   892
  qed        
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   893
next    
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   894
  case (Posix_FROMNTIMES3 s1 r v s2 vs v3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   895
      have "s1 \<in> r \<rightarrow> v" "s2 \<in> STAR r \<rightarrow> Stars vs" by fact+
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   896
  then have as1: "s1 = flat v" "s2 = flat (Stars vs)" by (auto dest: Posix1(2))
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   897
  have IH1: "\<And>v3. v3 \<in> LV r s1 \<Longrightarrow> v :\<sqsubseteq>val v3" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   898
  have IH2: "\<And>v3. v3 \<in> LV (STAR r) s2 \<Longrightarrow> Stars vs :\<sqsubseteq>val v3" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   899
  have cond: "\<not> (\<exists>s\<^sub>3 s\<^sub>4. s\<^sub>3 \<noteq> [] \<and> s\<^sub>3 @ s\<^sub>4 = s2 \<and> s1 @ s\<^sub>3 \<in> L r \<and> s\<^sub>4 \<in> L (STAR r))" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   900
  have cond2: "flat v \<noteq> []" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   901
  have "v3 \<in> LV (FROMNTIMES r 0) (s1 @ s2)" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   902
  then consider 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   903
    (NonEmpty) v3a vs3 where "v3 = Stars (v3a # vs3)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   904
    "\<Turnstile> v3a : r" "\<Turnstile> Stars vs3 : STAR r"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   905
    "flat (Stars (v3a # vs3)) = s1 @ s2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   906
  | (Empty) "v3 = Stars []" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   907
  unfolding LV_def  
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   908
  apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   909
  apply(erule Prf.cases)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   910
  apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   911
  apply(case_tac vs)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   912
  apply(auto intro: Prf.intros)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   913
  done
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   914
  then show "Stars (v # vs) :\<sqsubseteq>val v3" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   915
    proof (cases)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   916
      case (NonEmpty v3a vs3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   917
      have "flat (Stars (v3a # vs3)) = s1 @ s2" using NonEmpty(4) . 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   918
      with cond have "flat v3a \<sqsubseteq>pre s1" using NonEmpty(2,3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   919
        unfolding prefix_list_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   920
        by (smt L_flat_Prf1 append_Nil2 append_eq_append_conv2 flat.simps(7)) 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   921
      then have "flat v3a \<sqsubset>spre s1 \<or> (flat v3a = s1 \<and> flat (Stars vs3) = s2)" using NonEmpty(4)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   922
        by (simp add: sprefix_list_def append_eq_conv_conj)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   923
      then have q2: "v :\<sqsubset>val v3a \<or> (flat v3a = s1 \<and> flat (Stars vs3) = s2)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   924
        using PosOrd_spreI as1(1) NonEmpty(4) by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   925
      then have "v :\<sqsubset>val v3a \<or> (v3a \<in> LV r s1 \<and> Stars vs3 \<in> LV (STAR r) s2)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   926
        using NonEmpty(2,3) by (auto simp add: LV_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   927
      then have "v :\<sqsubset>val v3a \<or> (v :\<sqsubseteq>val v3a \<and> Stars vs :\<sqsubseteq>val Stars vs3)" using IH1 IH2 by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   928
      then have "v :\<sqsubset>val v3a \<or> (v = v3a \<and> Stars vs :\<sqsubseteq>val Stars vs3)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   929
         unfolding PosOrd_ex_eq_def by auto     
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   930
      then have "Stars (v # vs) :\<sqsubseteq>val Stars (v3a # vs3)" using NonEmpty(4) q2 as1
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   931
        unfolding  PosOrd_ex_eq_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   932
        using PosOrd_StarsI PosOrd_StarsI2 by auto 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   933
      then show "Stars (v # vs) :\<sqsubseteq>val v3" unfolding NonEmpty by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   934
    next 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   935
      case Empty
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   936
      have "v3 = Stars []" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   937
      then show "Stars (v # vs) :\<sqsubseteq>val v3"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   938
      unfolding PosOrd_ex_eq_def using cond2
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   939
      by (simp add: PosOrd_shorterI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   940
    qed      
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   941
next
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   942
  case (Posix_NMTIMES2 vs r n m v2) 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   943
  then show "Stars vs :\<sqsubseteq>val v2" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   944
    apply(auto simp add: LV_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   945
    apply(erule Prf_elims)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   946
     apply(simp)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   947
     apply(rule PosOrd_eq_Stars_zipI) 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   948
       apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   949
     apply (meson in_set_zipE)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   950
    by (metis Posix1(2) flats_empty)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   951
next
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   952
  case (Posix_NMTIMES1 s1 r v s2 n m vs v3) 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   953
  have "s1 \<in> r \<rightarrow> v" "s2 \<in> NMTIMES r (n - 1) (m - 1) \<rightarrow> Stars vs" by fact+
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   954
  then have as1: "s1 = flat v" "s2 = flats vs" by (auto dest: Posix1(2))
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   955
  have IH1: "\<And>v3. v3 \<in> LV r s1 \<Longrightarrow> v :\<sqsubseteq>val v3" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   956
  have IH2: "\<And>v3. v3 \<in> LV (NMTIMES r (n - 1) (m - 1)) s2 \<Longrightarrow> Stars vs :\<sqsubseteq>val v3" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   957
  have cond: "\<not> (\<exists>s\<^sub>3 s\<^sub>4. s\<^sub>3 \<noteq> [] \<and> s\<^sub>3 @ s\<^sub>4 = s2 \<and> s1 @ s\<^sub>3 \<in> L r \<and> s\<^sub>4 \<in> L (NMTIMES r (n - 1) (m - 1)))" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   958
  have cond2: "flat v \<noteq> []" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   959
  have "v3 \<in> LV (NMTIMES r n m) (s1 @ s2)" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   960
  then consider 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   961
    (NonEmpty) v3a vs3 where "v3 = Stars (v3a # vs3)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   962
    "\<Turnstile> v3a : r" "\<Turnstile> Stars vs3 : NMTIMES r (n - 1) (m - 1)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   963
    "flats (v3a # vs3) = s1 @ s2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   964
  | (Empty) "v3 = Stars []" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   965
  unfolding LV_def  
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   966
  apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   967
  apply(erule Prf.cases)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   968
             apply(auto)  
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   969
  apply(case_tac n)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   970
    apply(auto intro: Prf.intros)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   971
   apply(case_tac vs1)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   972
    apply(auto intro: Prf.intros)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   973
   apply (simp add: as1(1) cond2 flats_empty)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   974
   apply (simp add: Prf.intros(11))
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   975
  apply(case_tac n)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   976
   apply(simp)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   977
  using Posix_NMTIMES1.hyps(6) apply blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   978
  apply(simp)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   979
  apply(case_tac vs)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   980
   apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   981
  by (simp add: Prf.intros(12))
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   982
  then show "Stars (v # vs) :\<sqsubseteq>val v3" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   983
    proof (cases)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   984
      case (NonEmpty v3a vs3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   985
      have "flats (v3a # vs3) = s1 @ s2" using NonEmpty(4) . 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   986
      with cond have "flat v3a \<sqsubseteq>pre s1" using NonEmpty(2,3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   987
        unfolding prefix_list_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   988
        by (smt L_flat_Prf1 append_Nil2 append_eq_append_conv2 flat.simps(7) flat_Stars)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   989
      then have "flat v3a \<sqsubset>spre s1 \<or> (flat v3a = s1 \<and> flat (Stars vs3) = s2)" using NonEmpty(4)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   990
        by (simp add: sprefix_list_def append_eq_conv_conj)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   991
      then have q2: "v :\<sqsubset>val v3a \<or> (flat v3a = s1 \<and> flat (Stars vs3) = s2)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   992
        using PosOrd_spreI as1(1) NonEmpty(4) by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   993
      then have "v :\<sqsubset>val v3a \<or> (v3a \<in> LV r s1 \<and> Stars vs3 \<in> LV (NMTIMES r (n - 1) (m - 1)) s2)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   994
        using NonEmpty(2,3) by (auto simp add: LV_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   995
      then have "v :\<sqsubset>val v3a \<or> (v :\<sqsubseteq>val v3a \<and> Stars vs :\<sqsubseteq>val Stars vs3)" using IH1 IH2 by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   996
      then have "v :\<sqsubset>val v3a \<or> (v = v3a \<and> Stars vs :\<sqsubseteq>val Stars vs3)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   997
         unfolding PosOrd_ex_eq_def by auto     
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   998
      then have "Stars (v # vs) :\<sqsubseteq>val Stars (v3a # vs3)" using NonEmpty(4) q2 as1
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
   999
        unfolding  PosOrd_ex_eq_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1000
        using PosOrd_StarsI PosOrd_StarsI2 by auto 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1001
      then show "Stars (v # vs) :\<sqsubseteq>val v3" unfolding NonEmpty by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1002
    next 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1003
      case Empty
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1004
      have "v3 = Stars []" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1005
      then show "Stars (v # vs) :\<sqsubseteq>val v3"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1006
      unfolding PosOrd_ex_eq_def using cond2
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1007
      by (simp add: PosOrd_shorterI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1008
  qed        
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1009
next
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1010
  case (Posix_NMTIMES3 s1 r v s2 m vs v3) 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1011
  have "s1 \<in> r \<rightarrow> v" "s2 \<in> UPNTIMES r (m - 1) \<rightarrow> Stars vs" by fact+
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1012
  then have as1: "s1 = flat v" "s2 = flat (Stars vs)" by (auto dest: Posix1(2))
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1013
  have IH1: "\<And>v3. v3 \<in> LV r s1 \<Longrightarrow> v :\<sqsubseteq>val v3" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1014
  have IH2: "\<And>v3. v3 \<in> LV (UPNTIMES r (m - 1)) s2 \<Longrightarrow> Stars vs :\<sqsubseteq>val v3" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1015
  have cond: "\<not> (\<exists>s\<^sub>3 s\<^sub>4. s\<^sub>3 \<noteq> [] \<and> s\<^sub>3 @ s\<^sub>4 = s2 \<and> s1 @ s\<^sub>3 \<in> L r \<and> s\<^sub>4 \<in> L (UPNTIMES r (m - 1)))" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1016
  have cond2: "flat v \<noteq> []" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1017
  have "v3 \<in> LV (NMTIMES r 0 m) (s1 @ s2)" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1018
  then consider 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1019
    (NonEmpty) v3a vs3 where "v3 = Stars (v3a # vs3)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1020
    "\<Turnstile> v3a : r" "\<Turnstile> Stars vs3 : UPNTIMES r (m - 1)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1021
    "flats (v3a # vs3) = s1 @ s2"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1022
  | (Empty) "v3 = Stars []"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1023
  unfolding LV_def  
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1024
  apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1025
  apply(erule Prf.cases)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1026
  apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1027
  apply(case_tac vs)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1028
   apply(auto intro: Prf.intros)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1029
  by (simp add: Prf.intros(7) as1(1) cond2)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1030
  then show "Stars (v # vs) :\<sqsubseteq>val v3" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1031
    proof (cases)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1032
      case (NonEmpty v3a vs3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1033
      have "flats (v3a # vs3) = s1 @ s2" using NonEmpty(4) . 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1034
      with cond have "flat v3a \<sqsubseteq>pre s1" using NonEmpty(2,3)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1035
        unfolding prefix_list_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1036
        apply(simp)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1037
        apply(simp add: append_eq_append_conv2)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1038
        apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1039
        by (metis L_flat_Prf1 One_nat_def cond flat_Stars)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1040
      then have "flat v3a \<sqsubset>spre s1 \<or> (flat v3a = s1 \<and> flat (Stars vs3) = s2)" using NonEmpty(4)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1041
        by (simp add: sprefix_list_def append_eq_conv_conj)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1042
      then have q2: "v :\<sqsubset>val v3a \<or> (flat v3a = s1 \<and> flat (Stars vs3) = s2)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1043
        using PosOrd_spreI as1(1) NonEmpty(4) by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1044
      then have "v :\<sqsubset>val v3a \<or> (v3a \<in> LV r s1 \<and> Stars vs3 \<in> LV (UPNTIMES r (m - 1)) s2)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1045
        using NonEmpty(2,3) by (auto simp add: LV_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1046
      then have "v :\<sqsubset>val v3a \<or> (v :\<sqsubseteq>val v3a \<and> Stars vs :\<sqsubseteq>val Stars vs3)" using IH1 IH2 by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1047
      then have "v :\<sqsubset>val v3a \<or> (v = v3a \<and> Stars vs :\<sqsubseteq>val Stars vs3)" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1048
         unfolding PosOrd_ex_eq_def by auto     
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1049
      then have "Stars (v # vs) :\<sqsubseteq>val Stars (v3a # vs3)" using NonEmpty(4) q2 as1
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1050
        unfolding  PosOrd_ex_eq_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1051
        using PosOrd_StarsI PosOrd_StarsI2 by auto 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1052
      then show "Stars (v # vs) :\<sqsubseteq>val v3" unfolding NonEmpty by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1053
    next 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1054
      case Empty
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1055
      have "v3 = Stars []" by fact
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1056
      then show "Stars (v # vs) :\<sqsubseteq>val v3"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1057
      unfolding PosOrd_ex_eq_def using cond2
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1058
      by (simp add: PosOrd_shorterI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1059
  qed          
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1060
qed
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1061
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1062
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1063
lemma Posix_PosOrd_reverse:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1064
  assumes "s \<in> r \<rightarrow> v1" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1065
  shows "\<not>(\<exists>v2 \<in> LV r s. v2 :\<sqsubset>val v1)"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1066
using assms
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1067
by (metis Posix_PosOrd less_irrefl PosOrd_def 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1068
    PosOrd_ex_eq_def PosOrd_ex_def PosOrd_trans)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1069
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1070
lemma PosOrd_Posix:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1071
  assumes "v1 \<in> LV r s" "\<forall>v\<^sub>2 \<in> LV r s. \<not> v\<^sub>2 :\<sqsubset>val v1"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1072
  shows "s \<in> r \<rightarrow> v1" 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1073
proof -
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1074
  have "s \<in> L r" using assms(1) unfolding LV_def
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1075
    using L_flat_Prf1 by blast 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1076
  then obtain vposix where vp: "s \<in> r \<rightarrow> vposix"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1077
    using lexer_correct_Some by blast 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1078
  with assms(1) have "vposix :\<sqsubseteq>val v1" by (simp add: Posix_PosOrd) 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1079
  then have "vposix = v1 \<or> vposix :\<sqsubset>val v1" unfolding PosOrd_ex_eq2 by auto
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1080
  moreover
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1081
    { assume "vposix :\<sqsubset>val v1"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1082
      moreover
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1083
      have "vposix \<in> LV r s" using vp 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1084
         using Posix_LV by blast 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1085
      ultimately have "False" using assms(2) by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1086
    }
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1087
  ultimately show "s \<in> r \<rightarrow> v1" using vp by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1088
qed
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1089
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1090
lemma Least_existence:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1091
  assumes "LV r s \<noteq> {}"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1092
  shows " \<exists>vmin \<in> LV r s. \<forall>v \<in> LV r s. vmin :\<sqsubseteq>val v"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1093
proof -
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1094
  from assms
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1095
  obtain vposix where "s \<in> r \<rightarrow> vposix"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1096
  unfolding LV_def 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1097
  using L_flat_Prf1 lexer_correct_Some by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1098
  then have "\<forall>v \<in> LV r s. vposix :\<sqsubseteq>val v"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1099
    by (simp add: Posix_PosOrd)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1100
  then show "\<exists>vmin \<in> LV r s. \<forall>v \<in> LV r s. vmin :\<sqsubseteq>val v"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1101
    using Posix_LV \<open>s \<in> r \<rightarrow> vposix\<close> by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1102
qed 
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1103
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1104
lemma Least_existence1:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1105
  assumes "LV r s \<noteq> {}"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1106
  shows " \<exists>!vmin \<in> LV r s. \<forall>v \<in> LV r s. vmin :\<sqsubseteq>val v"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1107
using Least_existence[OF assms] assms
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1108
  using PosOrdeq_antisym by blast
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1109
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1110
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1111
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1112
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1113
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1114
lemma Least_existence1_pre:
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1115
  assumes "LV r s \<noteq> {}"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1116
  shows " \<exists>!vmin \<in> LV r s. \<forall>v \<in> (LV r s \<union> {v'. flat v' \<sqsubset>spre s}). vmin :\<sqsubseteq>val v"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1117
using Least_existence[OF assms] assms
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1118
apply -
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1119
apply(erule bexE)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1120
apply(rule_tac a="vmin" in ex1I)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1121
apply(auto)[1]
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1122
apply (metis PosOrd_Posix PosOrd_ex_eq2 PosOrd_spreI PosOrdeq_antisym Posix1(2))
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1123
apply(auto)[1]
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1124
apply(simp add: PosOrdeq_antisym)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1125
done
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1126
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1127
lemma
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1128
  shows "partial_order_on UNIV {(v1, v2). v1 :\<sqsubseteq>val v2}"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1129
apply(simp add: partial_order_on_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1130
apply(simp add: preorder_on_def refl_on_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1131
apply(simp add: PosOrdeq_refl)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1132
apply(auto)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1133
apply(rule transI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1134
apply(auto intro: PosOrdeq_trans)[1]
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1135
apply(rule antisymI)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1136
apply(simp add: PosOrdeq_antisym)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1137
done
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1138
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1139
lemma
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1140
 "wf {(v1, v2). v1 :\<sqsubset>val v2 \<and> v1 \<in> LV r s \<and> v2 \<in> LV r s}"
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1141
apply(rule finite_acyclic_wf)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1142
prefer 2
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1143
apply(simp add: acyclic_def)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1144
apply(induct_tac rule: trancl.induct)
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1145
     apply(auto)[1]
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1146
    prefer 3
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1147
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1148
oops
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1149
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1150
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1151
unused_thms
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1152
ec5e4fe4cc70 for new journal/conf paper!
Chengsong
parents:
diff changeset
  1153
end