| 1440 |      1 | 
 | 
|  |      2 | 
 | 
|  |      3 | (** lifting of quasi / partial orders **)
 | 
|  |      4 | 
 | 
|  |      5 | (* pairs *)
 | 
|  |      6 | 
 | 
| 5069 |      7 | Goalw [le_prod_def] "x [= (x::'a::quasi_order*'b::quasi_order)";
 | 
| 4153 |      8 |   by (rtac conjI 1);
 | 
|  |      9 |   by (rtac le_refl 1);
 | 
|  |     10 |   by (rtac le_refl 1);
 | 
| 1440 |     11 | qed "le_prod_refl";
 | 
|  |     12 | 
 | 
| 5069 |     13 | Goalw [le_prod_def] "x [= y & y [= z --> x [= (z::'a::quasi_order*'b::quasi_order)";
 | 
| 4153 |     14 |   by Safe_tac;
 | 
|  |     15 |   by (etac (conjI RS (le_trans RS mp)) 1);
 | 
|  |     16 |   by (assume_tac 1);
 | 
|  |     17 |   by (etac (conjI RS (le_trans RS mp)) 1);
 | 
|  |     18 |   by (assume_tac 1);
 | 
| 1440 |     19 | qed "le_prod_trans";
 | 
|  |     20 | 
 | 
| 5069 |     21 | Goalw [le_prod_def] "x [= y & y [= x --> x = (y::'a::partial_order*'b::partial_order)";
 | 
| 4153 |     22 |   by Safe_tac;
 | 
| 1440 |     23 |   by (stac Pair_fst_snd_eq 1);
 | 
| 4153 |     24 |   by (rtac conjI 1);
 | 
|  |     25 |   by (etac (conjI RS (le_antisym RS mp)) 1);
 | 
|  |     26 |   by (assume_tac 1);
 | 
|  |     27 |   by (etac (conjI RS (le_antisym RS mp)) 1);
 | 
|  |     28 |   by (assume_tac 1);
 | 
| 1440 |     29 | qed "le_prod_antisym";
 | 
|  |     30 | 
 | 
|  |     31 | 
 | 
|  |     32 | (* functions *)
 | 
|  |     33 | 
 | 
| 5069 |     34 | Goalw [le_fun_def] "f [= (f::'a=>'b::quasi_order)";
 | 
| 4153 |     35 |   by (rtac allI 1);
 | 
|  |     36 |   by (rtac le_refl 1);
 | 
| 1440 |     37 | qed "le_fun_refl";
 | 
|  |     38 | 
 | 
| 5069 |     39 | Goalw [le_fun_def] "f [= g & g [= h --> f [= (h::'a=>'b::quasi_order)";
 | 
| 4153 |     40 |   by Safe_tac;
 | 
|  |     41 |   by (rtac (le_trans RS mp) 1);
 | 
| 1899 |     42 |   by (Fast_tac 1);
 | 
| 1440 |     43 | qed "le_fun_trans";
 | 
|  |     44 | 
 | 
| 5069 |     45 | Goalw [le_fun_def] "f [= g & g [= f --> f = (g::'a=>'b::partial_order)";
 | 
| 4153 |     46 |   by Safe_tac;
 | 
|  |     47 |   by (rtac ext 1);
 | 
|  |     48 |   by (rtac (le_antisym RS mp) 1);
 | 
| 1899 |     49 |   by (Fast_tac 1);
 | 
| 1440 |     50 | qed "le_fun_antisym";
 | 
|  |     51 | 
 | 
|  |     52 | 
 | 
|  |     53 | 
 | 
|  |     54 | (** duals **)
 | 
|  |     55 | 
 | 
|  |     56 | (*"'a dual" is even an isotype*)
 | 
| 5069 |     57 | Goal "Rep_dual (Abs_dual y) = y";
 | 
| 4153 |     58 |   by (rtac Abs_dual_inverse 1);
 | 
| 1465 |     59 |   by (rewtac dual_def);
 | 
| 1899 |     60 |   by (Fast_tac 1);
 | 
| 1440 |     61 | qed "Abs_dual_inverse'";
 | 
|  |     62 | 
 | 
|  |     63 | 
 | 
| 5069 |     64 | Goalw [le_dual_def] "x [= (x::'a::quasi_order dual)";
 | 
| 4153 |     65 |   by (rtac le_refl 1);
 | 
| 1440 |     66 | qed "le_dual_refl";
 | 
|  |     67 | 
 | 
| 5069 |     68 | Goalw [le_dual_def] "x [= y & y [= z --> x [= (z::'a::quasi_order dual)";
 | 
| 6162 |     69 |   by (rtac impI 1);
 | 
|  |     70 |   by (rtac (le_trans RS mp) 1);
 | 
| 5712 |     71 |   by (Blast_tac 1);
 | 
| 1440 |     72 | qed "le_dual_trans";
 | 
|  |     73 | 
 | 
| 5069 |     74 | Goalw [le_dual_def] "x [= y & y [= x --> x = (y::'a::partial_order dual)";
 | 
| 4153 |     75 |   by Safe_tac;
 | 
|  |     76 |   by (rtac (Rep_dual_inverse RS subst) 1);
 | 
|  |     77 |   by (rtac sym 1);
 | 
|  |     78 |   by (rtac (Rep_dual_inverse RS subst) 1);
 | 
|  |     79 |   by (rtac arg_cong 1);
 | 
| 1440 |     80 |   back();
 | 
| 4153 |     81 |   by (etac (conjI RS (le_antisym RS mp)) 1);
 | 
|  |     82 |   by (assume_tac 1);
 | 
| 1440 |     83 | qed "le_dual_antisym";
 | 
|  |     84 | 
 | 
| 5069 |     85 | Goalw [le_dual_def] "x [= y | y [= (x::'a::linear_order dual)";
 | 
| 4153 |     86 |   by (rtac le_linear 1);
 | 
| 2606 |     87 | qed "le_dual_linear";
 |