-lemma og_ordered_set: pre_ordered_abelian_group → ordered_set.
- intro G;
- apply mk_ordered_set;
- [ apply (carrier (og_abelian_group G))
- | apply (eq_rect ? ? (λC:Type.C→C→Prop) ? ? (og_with G));
- apply os_le
- | apply
- (eq_rect' ? ?
- (λa:Type.λH:os_carrier (og_ordered_set_ G) = a.
- is_order_relation a
- (eq_rect Type (og_ordered_set_ G) (λC:Type.C→C→Prop)
- (os_le (og_ordered_set_ G)) a H))
- ? ? (og_with G));
- simplify;
- apply (os_order_relation_properties (og_ordered_set_ G))
- ]
+lemma og_tordered_set: pre_ordered_abelian_group → tordered_set.
+intro G; apply mk_tordered_set;
+[1: apply mk_pordered_set;
+ [1: apply (mk_excedence G);
+ [1: cases G; clear G; simplify; rewrite < H; clear H;
+ cases og_tordered_set_; clear og_tordered_set_; simplify;
+ cases tos_poset; simplify; cases pos_carr; simplify; assumption;
+ |2: cases G; simplify; cases H; simplify; clear H;
+ cases og_tordered_set_; simplify; clear og_tordered_set_;
+ cases tos_poset; simplify; cases pos_carr; simplify;
+ intros; apply H;
+ |3: cases G; simplify; cases H; simplify; cases og_tordered_set_; simplify;
+ cases tos_poset; simplify; cases pos_carr; simplify;
+ intros; apply c; assumption]
+ |2: cases G; simplify;
+ cases H; simplify; clear H; cases og_tordered_set_; simplify;
+ cases tos_poset; simplify; assumption;]
+|2: simplify; (* SLOW, senza la simplify il widget muore *)
+ cases G; simplify;
+ generalize in match (tos_totality og_tordered_set_);
+ unfold total_order_property;
+ cases H; simplify; cases og_tordered_set_; simplify;
+ cases tos_poset; simplify; cases pos_carr; simplify;
+ intros; apply f; assumption;]